@taiga-ui/core 3.30.0 → 3.31.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/taiga-ui-core-components-root.umd.js +13 -3
- package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-svg.umd.js +16 -10
- package/bundles/taiga-ui-core-components-svg.umd.js.map +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js +3 -1
- package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
- package/components/root/root.component.d.ts +3 -1
- package/components/svg/svg-options.d.ts +4 -2
- package/components/svg/svg.component.d.ts +3 -3
- package/constants/cache-basting-payload.d.ts +1 -1
- package/esm2015/components/root/root.component.js +15 -5
- package/esm2015/components/svg/svg-options.js +13 -9
- package/esm2015/components/svg/svg.component.js +6 -5
- package/esm2015/tokens/icon-place.js +3 -2
- package/fesm2015/taiga-ui-core-components-root.js +14 -4
- package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-svg.js +16 -11
- package/fesm2015/taiga-ui-core-components-svg.js.map +1 -1
- package/fesm2015/taiga-ui-core-tokens.js +3 -2
- package/fesm2015/taiga-ui-core-tokens.js.map +1 -1
- package/package.json +4 -4
- package/tokens/icon-place.d.ts +1 -0
|
@@ -1,18 +1,20 @@
|
|
|
1
1
|
import { FactoryProvider, InjectionToken, Provider } from '@angular/core';
|
|
2
2
|
import { TuiHandler, TuiSafeHtml, TuiStringHandler } from '@taiga-ui/cdk';
|
|
3
3
|
export interface TuiSvgOptions {
|
|
4
|
+
readonly iconsPlace: string;
|
|
4
5
|
readonly path: TuiStringHandler<string>;
|
|
5
6
|
readonly deprecated: TuiStringHandler<string>;
|
|
6
7
|
readonly srcProcessor: TuiHandler<TuiSafeHtml, TuiSafeHtml>;
|
|
7
8
|
readonly contentProcessor: TuiHandler<TuiSafeHtml, TuiSafeHtml>;
|
|
8
9
|
}
|
|
10
|
+
export declare type TuiSvgInterceptorHandler = ((src: TuiSafeHtml, options: TuiSvgOptions) => TuiSafeHtml) | ((src: TuiSafeHtml) => TuiSafeHtml);
|
|
9
11
|
export declare const TUI_SVG_DEFAULT_OPTIONS: TuiSvgOptions;
|
|
10
12
|
/**
|
|
11
13
|
* SVG component options
|
|
12
14
|
*/
|
|
13
15
|
export declare const TUI_SVG_OPTIONS: InjectionToken<TuiSvgOptions>;
|
|
14
|
-
export declare const TUI_SVG_SRC_INTERCEPTORS: InjectionToken<
|
|
15
|
-
export declare function tuiSvgSrcInterceptors(interceptor:
|
|
16
|
+
export declare const TUI_SVG_SRC_INTERCEPTORS: InjectionToken<TuiSvgInterceptorHandler>;
|
|
17
|
+
export declare function tuiSvgSrcInterceptors(interceptor: TuiSvgInterceptorHandler): Provider;
|
|
16
18
|
export declare const tuiSvgOptionsProvider: (options: Partial<Omit<TuiSvgOptions, 'path'>> & {
|
|
17
19
|
path?: TuiSvgOptions['path'] | string;
|
|
18
20
|
}) => FactoryProvider;
|
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { ElementRef, Sanitizer } from '@angular/core';
|
|
2
2
|
import { DomSanitizer, SafeHtml } from '@angular/platform-browser';
|
|
3
|
-
import {
|
|
3
|
+
import { TuiSafeHtml, TuiStaticRequestService } from '@taiga-ui/cdk';
|
|
4
4
|
import { TuiSvgService } from '@taiga-ui/core/services';
|
|
5
5
|
import { Observable } from 'rxjs';
|
|
6
|
-
import { TuiSvgOptions } from './svg-options';
|
|
6
|
+
import { TuiSvgInterceptorHandler, TuiSvgOptions } from './svg-options';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
export declare class TuiSvgComponent {
|
|
9
9
|
private readonly doc;
|
|
@@ -18,7 +18,7 @@ export declare class TuiSvgComponent {
|
|
|
18
18
|
private readonly src$;
|
|
19
19
|
private icon;
|
|
20
20
|
readonly innerHTML$: Observable<SafeHtml>;
|
|
21
|
-
constructor(doc: Document, win: Window, options: TuiSvgOptions, srcInterceptors:
|
|
21
|
+
constructor(doc: Document, win: Window, options: TuiSvgOptions, srcInterceptors: readonly TuiSvgInterceptorHandler[] | null, tuiSanitizer: Sanitizer | null, svgService: TuiSvgService, staticRequestService: TuiStaticRequestService, sanitizer: DomSanitizer, el: ElementRef<Element>);
|
|
22
22
|
set src(src: TuiSafeHtml);
|
|
23
23
|
get src(): TuiSafeHtml;
|
|
24
24
|
get use(): string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export declare const TUI_CACHE_BUSTING_PAYLOAD: "?v=3.
|
|
1
|
+
export declare const TUI_CACHE_BUSTING_PAYLOAD: "?v=3.31.0";
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DOCUMENT } from '@angular/common';
|
|
2
2
|
import { ChangeDetectionStrategy, Component, Inject, ViewEncapsulation, } from '@angular/core';
|
|
3
|
-
import { TUI_DIALOGS, TUI_IS_MOBILE, TUI_VERSION } from '@taiga-ui/cdk';
|
|
3
|
+
import { TUI_DIALOGS, TUI_IS_ANDROID, TUI_IS_IOS, TUI_IS_MOBILE, TUI_VERSION, } from '@taiga-ui/cdk';
|
|
4
4
|
import { TUI_IS_MOBILE_RES_PROVIDER } from '@taiga-ui/core/providers';
|
|
5
5
|
import { TUI_ANIMATIONS_DURATION, TUI_IS_MOBILE_RES, TUI_THEME, } from '@taiga-ui/core/tokens';
|
|
6
6
|
import { combineLatest, of } from 'rxjs';
|
|
@@ -13,19 +13,21 @@ import * as i4 from "@taiga-ui/core/components/hints-host";
|
|
|
13
13
|
import * as i5 from "@angular/common";
|
|
14
14
|
import * as i6 from "rxjs";
|
|
15
15
|
export class TuiRootComponent {
|
|
16
|
-
constructor(duration, dialogs, isMobile, isMobileRes$, { body }, theme) {
|
|
16
|
+
constructor(duration, dialogs, isMobile, isMobileRes$, isIOS, isAndroid, { body }, theme) {
|
|
17
17
|
this.duration = duration;
|
|
18
18
|
this.dialogs = dialogs;
|
|
19
19
|
this.isMobile = isMobile;
|
|
20
20
|
this.isMobileRes$ = isMobileRes$;
|
|
21
|
+
this.isIOS = isIOS;
|
|
22
|
+
this.isAndroid = isAndroid;
|
|
21
23
|
this.scrollbars$ = this.dialogs.length && !this.isMobile
|
|
22
24
|
? combineLatest([...this.dialogs]).pipe(map(dialogs => !dialogs.some(({ length }) => length)))
|
|
23
25
|
: of(!this.isMobile);
|
|
24
26
|
body.setAttribute('data-tui-theme', theme.toLowerCase());
|
|
25
27
|
}
|
|
26
28
|
}
|
|
27
|
-
TuiRootComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, deps: [{ token: TUI_ANIMATIONS_DURATION }, { token: TUI_DIALOGS }, { token: TUI_IS_MOBILE }, { token: TUI_IS_MOBILE_RES }, { token: DOCUMENT }, { token: TUI_THEME }], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
-
TuiRootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiRootComponent, selector: "tui-root", host: { attributes: { "data-tui-version": "3.
|
|
29
|
+
TuiRootComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, deps: [{ token: TUI_ANIMATIONS_DURATION }, { token: TUI_DIALOGS }, { token: TUI_IS_MOBILE }, { token: TUI_IS_MOBILE_RES }, { token: TUI_IS_IOS }, { token: TUI_IS_ANDROID }, { token: DOCUMENT }, { token: TUI_THEME }], target: i0.ɵɵFactoryTarget.Component });
|
|
30
|
+
TuiRootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiRootComponent, selector: "tui-root", host: { attributes: { "data-tui-version": "3.31.0" }, listeners: { "$.class._mobile": "isMobileRes$" }, properties: { "style.--tui-duration.ms": "duration", "class._ios": "isIOS", "class._android": "isAndroid" } }, providers: [TUI_IS_MOBILE_RES_PROVIDER], ngImport: i0, template: "<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n></tui-scroll-controls>\n<tui-svg-defs-host></tui-svg-defs-host>\n<tui-dropdown-host>\n <div class=\"t-root-content\">\n <ng-content></ng-content>\n </div>\n <ng-content select=\"tuiOverContent\"></ng-content>\n <tui-dialog-host></tui-dialog-host>\n <ng-content select=\"tuiOverDialogs\"></ng-content>\n <tui-alert-host></tui-alert-host>\n <ng-content select=\"tuiOverAlerts\"></ng-content>\n</tui-dropdown-host>\n<ng-content select=\"tuiOverPortals\"></ng-content>\n<tui-hints-host></tui-hints-host>\n<ng-content select=\"tuiOverHints\"></ng-content>\n", styles: ["@keyframes tuiPresent{to{content:\"1\"}}html,.tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar,html::-webkit-scrollbar-thumb,.tui-zero-scrollbar::-webkit-scrollbar-thumb{background:transparent;width:0;height:0}body{font:var(--tui-font-text-s);color:var(--tui-text-01);margin:0}tui-root{position:relative;display:block;flex:1;-webkit-tap-highlight-color:transparent}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;margin:0}.t-root-content{position:relative;z-index:0;height:100%}\n"], components: [{ type: i1.TuiScrollControlsComponent, selector: "tui-scroll-controls" }, { type: i2.TuiSvgDefsHostComponent, selector: "tui-svg-defs-host" }, { type: i3.TuiDropdownHostComponent, selector: "tui-dropdown-host" }, { type: i3.TuiDialogHostComponent, selector: "tui-dialog-host" }, { type: i3.TuiAlertHostComponent, selector: "tui-alert-host" }, { type: i4.TuiHintsHostComponent, selector: "tui-hints-host" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
|
29
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, decorators: [{
|
|
30
32
|
type: Component,
|
|
31
33
|
args: [{
|
|
@@ -40,6 +42,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
40
42
|
host: {
|
|
41
43
|
'data-tui-version': TUI_VERSION,
|
|
42
44
|
'[style.--tui-duration.ms]': 'duration',
|
|
45
|
+
'[class._ios]': 'isIOS',
|
|
46
|
+
'[class._android]': 'isAndroid',
|
|
43
47
|
'($.class._mobile)': 'isMobileRes$',
|
|
44
48
|
},
|
|
45
49
|
}]
|
|
@@ -55,6 +59,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
55
59
|
}] }, { type: i6.Observable, decorators: [{
|
|
56
60
|
type: Inject,
|
|
57
61
|
args: [TUI_IS_MOBILE_RES]
|
|
62
|
+
}] }, { type: undefined, decorators: [{
|
|
63
|
+
type: Inject,
|
|
64
|
+
args: [TUI_IS_IOS]
|
|
65
|
+
}] }, { type: undefined, decorators: [{
|
|
66
|
+
type: Inject,
|
|
67
|
+
args: [TUI_IS_ANDROID]
|
|
58
68
|
}] }, { type: Document, decorators: [{
|
|
59
69
|
type: Inject,
|
|
60
70
|
args: [DOCUMENT]
|
|
@@ -62,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
62
72
|
type: Inject,
|
|
63
73
|
args: [TUI_THEME]
|
|
64
74
|
}] }]; } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicm9vdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvcm9vdC9yb290LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9yb290L3Jvb3QudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDekMsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsTUFBTSxFQUNOLGlCQUFpQixHQUNwQixNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQ0gsV0FBVyxFQUNYLGNBQWMsRUFDZCxVQUFVLEVBQ1YsYUFBYSxFQUNiLFdBQVcsR0FDZCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNwRSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLGlCQUFpQixFQUNqQixTQUFTLEdBQ1osTUFBTSx1QkFBdUIsQ0FBQztBQUMvQixPQUFPLEVBQUMsYUFBYSxFQUFjLEVBQUUsRUFBQyxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUMsR0FBRyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7Ozs7O0FBbUJuQyxNQUFNLE9BQU8sZ0JBQWdCO0lBUXpCLFlBQzhDLFFBQWdCLEVBRWpELE9BQXNELEVBQ3ZCLFFBQWlCLEVBQ3JCLFlBQWlDLEVBQ3hDLEtBQWMsRUFDVixTQUFrQixFQUNqQyxFQUFDLElBQUksRUFBVyxFQUNmLEtBQWE7UUFSVSxhQUFRLEdBQVIsUUFBUSxDQUFRO1FBRWpELFlBQU8sR0FBUCxPQUFPLENBQStDO1FBQ3ZCLGFBQVEsR0FBUixRQUFRLENBQVM7UUFDckIsaUJBQVksR0FBWixZQUFZLENBQXFCO1FBQ3hDLFVBQUssR0FBTCxLQUFLLENBQVM7UUFDVixjQUFTLEdBQVQsU0FBUyxDQUFTO1FBZDlDLGdCQUFXLEdBQ2hCLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVE7WUFDakMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUNqQyxHQUFHLENBQUMsT0FBTyxDQUFDLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxFQUFDLE1BQU0sRUFBQyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUN0RDtZQUNILENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFhekIsSUFBSSxDQUFDLFlBQVksQ0FBQyxnQkFBZ0IsRUFBRSxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUMsQ0FBQztJQUM3RCxDQUFDOzs4R0FwQlEsZ0JBQWdCLGtCQVNiLHVCQUF1QixhQUN2QixXQUFXLGFBRVgsYUFBYSxhQUNiLGlCQUFpQixhQUNqQixVQUFVLGFBQ1YsY0FBYyxhQUNkLFFBQVEsYUFDUixTQUFTO2tHQWpCWixnQkFBZ0IsMFBBVmQsQ0FBQywwQkFBMEIsQ0FBQywwQkM5QjNDLGdxQkFrQkE7NEZEc0JhLGdCQUFnQjtrQkFqQjVCLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLFVBQVU7b0JBQ3BCLFdBQVcsRUFBRSxzQkFBc0I7b0JBQ25DLFNBQVMsRUFBRSxDQUFDLG1CQUFtQixDQUFDO29CQUNoQyxtREFBbUQ7b0JBQ25ELHFGQUFxRjtvQkFDckYsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE9BQU87b0JBQ2hELFNBQVMsRUFBRSxDQUFDLDBCQUEwQixDQUFDO29CQUN2QyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsSUFBSTtvQkFDckMsSUFBSSxFQUFFO3dCQUNGLGtCQUFrQixFQUFFLFdBQVc7d0JBQy9CLDJCQUEyQixFQUFFLFVBQVU7d0JBQ3ZDLGNBQWMsRUFBRSxPQUFPO3dCQUN2QixrQkFBa0IsRUFBRSxXQUFXO3dCQUMvQixtQkFBbUIsRUFBRSxjQUFjO3FCQUN0QztpQkFDSjs7MEJBVVEsTUFBTTsyQkFBQyx1QkFBdUI7OzBCQUM5QixNQUFNOzJCQUFDLFdBQVc7OzBCQUVsQixNQUFNOzJCQUFDLGFBQWE7OzBCQUNwQixNQUFNOzJCQUFDLGlCQUFpQjs7MEJBQ3hCLE1BQU07MkJBQUMsVUFBVTs7MEJBQ2pCLE1BQU07MkJBQUMsY0FBYzs4QkFDSSxRQUFROzBCQUFqQyxNQUFNOzJCQUFDLFFBQVE7OzBCQUNmLE1BQU07MkJBQUMsU0FBUyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RE9DVU1FTlR9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBJbmplY3QsXG4gICAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtcbiAgICBUVUlfRElBTE9HUyxcbiAgICBUVUlfSVNfQU5EUk9JRCxcbiAgICBUVUlfSVNfSU9TLFxuICAgIFRVSV9JU19NT0JJTEUsXG4gICAgVFVJX1ZFUlNJT04sXG59IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUVUlfSVNfTU9CSUxFX1JFU19QUk9WSURFUn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvcHJvdmlkZXJzJztcbmltcG9ydCB7XG4gICAgVFVJX0FOSU1BVElPTlNfRFVSQVRJT04sXG4gICAgVFVJX0lTX01PQklMRV9SRVMsXG4gICAgVFVJX1RIRU1FLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZS90b2tlbnMnO1xuaW1wb3J0IHtjb21iaW5lTGF0ZXN0LCBPYnNlcnZhYmxlLCBvZn0gZnJvbSAncnhqcyc7XG5pbXBvcnQge21hcH0gZnJvbSAncnhqcy9vcGVyYXRvcnMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1yb290JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcm9vdC50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9yb290LnN0eWxlLmxlc3MnXSxcbiAgICAvLyBTbyB0aGF0IHdlIGRvIG5vdCBmb3JjZSBPblB1c2ggb24gY3VzdG9tIGRpYWxvZ3NcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQGFuZ3VsYXItZXNsaW50L3ByZWZlci1vbi1wdXNoLWNvbXBvbmVudC1jaGFuZ2UtZGV0ZWN0aW9uXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5EZWZhdWx0LFxuICAgIHByb3ZpZGVyczogW1RVSV9JU19NT0JJTEVfUkVTX1BST1ZJREVSXSxcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJ2RhdGEtdHVpLXZlcnNpb24nOiBUVUlfVkVSU0lPTixcbiAgICAgICAgJ1tzdHlsZS4tLXR1aS1kdXJhdGlvbi5tc10nOiAnZHVyYXRpb24nLFxuICAgICAgICAnW2NsYXNzLl9pb3NdJzogJ2lzSU9TJyxcbiAgICAgICAgJ1tjbGFzcy5fYW5kcm9pZF0nOiAnaXNBbmRyb2lkJyxcbiAgICAgICAgJygkLmNsYXNzLl9tb2JpbGUpJzogJ2lzTW9iaWxlUmVzJCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUm9vdENvbXBvbmVudCB7XG4gICAgcmVhZG9ubHkgc2Nyb2xsYmFycyQ6IE9ic2VydmFibGU8Ym9vbGVhbj4gPVxuICAgICAgICB0aGlzLmRpYWxvZ3MubGVuZ3RoICYmICF0aGlzLmlzTW9iaWxlXG4gICAgICAgICAgICA/IGNvbWJpbmVMYXRlc3QoWy4uLnRoaXMuZGlhbG9nc10pLnBpcGUoXG4gICAgICAgICAgICAgICAgICBtYXAoZGlhbG9ncyA9PiAhZGlhbG9ncy5zb21lKCh7bGVuZ3RofSkgPT4gbGVuZ3RoKSksXG4gICAgICAgICAgICAgIClcbiAgICAgICAgICAgIDogb2YoIXRoaXMuaXNNb2JpbGUpO1xuXG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBJbmplY3QoVFVJX0FOSU1BVElPTlNfRFVSQVRJT04pIHJlYWRvbmx5IGR1cmF0aW9uOiBudW1iZXIsXG4gICAgICAgIEBJbmplY3QoVFVJX0RJQUxPR1MpXG4gICAgICAgIHJlYWRvbmx5IGRpYWxvZ3M6IFJlYWRvbmx5QXJyYXk8T2JzZXJ2YWJsZTxyZWFkb25seSB1bmtub3duW10+PixcbiAgICAgICAgQEluamVjdChUVUlfSVNfTU9CSUxFKSBwcml2YXRlIHJlYWRvbmx5IGlzTW9iaWxlOiBib29sZWFuLFxuICAgICAgICBASW5qZWN0KFRVSV9JU19NT0JJTEVfUkVTKSByZWFkb25seSBpc01vYmlsZVJlcyQ6IE9ic2VydmFibGU8Ym9vbGVhbj4sXG4gICAgICAgIEBJbmplY3QoVFVJX0lTX0lPUykgcmVhZG9ubHkgaXNJT1M6IGJvb2xlYW4sXG4gICAgICAgIEBJbmplY3QoVFVJX0lTX0FORFJPSUQpIHJlYWRvbmx5IGlzQW5kcm9pZDogYm9vbGVhbixcbiAgICAgICAgQEluamVjdChET0NVTUVOVCkge2JvZHl9OiBEb2N1bWVudCxcbiAgICAgICAgQEluamVjdChUVUlfVEhFTUUpIHRoZW1lOiBzdHJpbmcsXG4gICAgKSB7XG4gICAgICAgIGJvZHkuc2V0QXR0cmlidXRlKCdkYXRhLXR1aS10aGVtZScsIHRoZW1lLnRvTG93ZXJDYXNlKCkpO1xuICAgIH1cbn1cbiIsIjx0dWktc2Nyb2xsLWNvbnRyb2xzXG4gICAgKm5nSWY9XCJzY3JvbGxiYXJzJCB8IGFzeW5jXCJcbiAgICBjbGFzcz1cInQtcm9vdC1zY3JvbGxiYXJcIlxuPjwvdHVpLXNjcm9sbC1jb250cm9scz5cbjx0dWktc3ZnLWRlZnMtaG9zdD48L3R1aS1zdmctZGVmcy1ob3N0PlxuPHR1aS1kcm9wZG93bi1ob3N0PlxuICAgIDxkaXYgY2xhc3M9XCJ0LXJvb3QtY29udGVudFwiPlxuICAgICAgICA8bmctY29udGVudD48L25nLWNvbnRlbnQ+XG4gICAgPC9kaXY+XG4gICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpT3ZlckNvbnRlbnRcIj48L25nLWNvbnRlbnQ+XG4gICAgPHR1aS1kaWFsb2ctaG9zdD48L3R1aS1kaWFsb2ctaG9zdD5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0dWlPdmVyRGlhbG9nc1wiPjwvbmctY29udGVudD5cbiAgICA8dHVpLWFsZXJ0LWhvc3Q+PC90dWktYWxlcnQtaG9zdD5cbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJ0dWlPdmVyQWxlcnRzXCI+PC9uZy1jb250ZW50PlxuPC90dWktZHJvcGRvd24taG9zdD5cbjxuZy1jb250ZW50IHNlbGVjdD1cInR1aU92ZXJQb3J0YWxzXCI+PC9uZy1jb250ZW50PlxuPHR1aS1oaW50cy1ob3N0PjwvdHVpLWhpbnRzLWhvc3Q+XG48bmctY29udGVudCBzZWxlY3Q9XCJ0dWlPdmVySGludHNcIj48L25nLWNvbnRlbnQ+XG4iXX0=
|
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { inject, InjectionToken, Optional, SkipSelf, } from '@angular/core';
|
|
2
2
|
import { tuiIsString, tuiSvgLinearGradientProcessor, } from '@taiga-ui/cdk';
|
|
3
|
-
import { TUI_ICONS_PATH, TUI_SVG_CONTENT_PROCESSOR, TUI_SVG_SRC_PROCESSOR, } from '@taiga-ui/core/tokens';
|
|
3
|
+
import { TUI_DEFAULT_ICONS_PLACE, TUI_ICONS_PATH, TUI_ICONS_PLACE, TUI_SVG_CONTENT_PROCESSOR, TUI_SVG_SRC_PROCESSOR, } from '@taiga-ui/core/tokens';
|
|
4
4
|
import { tuiIconsPathFactory } from '@taiga-ui/core/utils';
|
|
5
5
|
import { identity } from 'rxjs';
|
|
6
6
|
import { TUI_DEPRECATED_ICONS } from './deprecated-icons';
|
|
7
7
|
export const TUI_SVG_DEFAULT_OPTIONS = {
|
|
8
|
-
|
|
8
|
+
iconsPlace: TUI_DEFAULT_ICONS_PLACE,
|
|
9
|
+
path: tuiIconsPathFactory(TUI_DEFAULT_ICONS_PLACE),
|
|
9
10
|
srcProcessor: identity,
|
|
10
11
|
contentProcessor: tuiSvgLinearGradientProcessor,
|
|
11
12
|
deprecated: src => {
|
|
@@ -21,6 +22,7 @@ export const TUI_SVG_DEFAULT_OPTIONS = {
|
|
|
21
22
|
*/
|
|
22
23
|
export const TUI_SVG_OPTIONS = new InjectionToken(`[TUI_SVG_OPTIONS]`, {
|
|
23
24
|
factory: () => ({
|
|
25
|
+
iconsPlace: inject(TUI_ICONS_PLACE),
|
|
24
26
|
path: inject(TUI_ICONS_PATH),
|
|
25
27
|
deprecated: TUI_SVG_DEFAULT_OPTIONS.deprecated,
|
|
26
28
|
srcProcessor: inject(TUI_SVG_SRC_PROCESSOR),
|
|
@@ -39,20 +41,22 @@ export const tuiSvgOptionsProvider = options => ({
|
|
|
39
41
|
provide: TUI_SVG_OPTIONS,
|
|
40
42
|
deps: [
|
|
41
43
|
[new SkipSelf(), new Optional(), TUI_SVG_OPTIONS],
|
|
44
|
+
[new Optional(), TUI_ICONS_PLACE],
|
|
42
45
|
[new Optional(), TUI_ICONS_PATH],
|
|
43
46
|
[new Optional(), TUI_SVG_SRC_PROCESSOR],
|
|
44
47
|
[new Optional(), TUI_SVG_CONTENT_PROCESSOR],
|
|
45
48
|
],
|
|
46
|
-
useFactory: (fallback, path, srcProcessor, contentProcessor) => {
|
|
47
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
49
|
+
useFactory: (fallback, iconsPlace, path, srcProcessor, contentProcessor) => {
|
|
50
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
|
|
48
51
|
return ({
|
|
52
|
+
iconsPlace: (_c = (_b = (_a = options.iconsPlace) !== null && _a !== void 0 ? _a : fallback === null || fallback === void 0 ? void 0 : fallback.iconsPlace) !== null && _b !== void 0 ? _b : iconsPlace) !== null && _c !== void 0 ? _c : TUI_SVG_DEFAULT_OPTIONS.iconsPlace,
|
|
49
53
|
path: tuiIsString(options.path)
|
|
50
54
|
? tuiIconsPathFactory(options.path)
|
|
51
|
-
: (
|
|
52
|
-
deprecated: (
|
|
53
|
-
srcProcessor: (
|
|
54
|
-
contentProcessor: (
|
|
55
|
+
: (_f = (_e = (_d = options.path) !== null && _d !== void 0 ? _d : fallback === null || fallback === void 0 ? void 0 : fallback.path) !== null && _e !== void 0 ? _e : path) !== null && _f !== void 0 ? _f : TUI_SVG_DEFAULT_OPTIONS.path,
|
|
56
|
+
deprecated: (_h = (_g = options.deprecated) !== null && _g !== void 0 ? _g : fallback === null || fallback === void 0 ? void 0 : fallback.deprecated) !== null && _h !== void 0 ? _h : TUI_SVG_DEFAULT_OPTIONS.deprecated,
|
|
57
|
+
srcProcessor: (_l = (_k = (_j = options.srcProcessor) !== null && _j !== void 0 ? _j : fallback === null || fallback === void 0 ? void 0 : fallback.srcProcessor) !== null && _k !== void 0 ? _k : srcProcessor) !== null && _l !== void 0 ? _l : TUI_SVG_DEFAULT_OPTIONS.srcProcessor,
|
|
58
|
+
contentProcessor: (_p = (_o = (_m = options.contentProcessor) !== null && _m !== void 0 ? _m : fallback === null || fallback === void 0 ? void 0 : fallback.contentProcessor) !== null && _o !== void 0 ? _o : contentProcessor) !== null && _p !== void 0 ? _p : TUI_SVG_DEFAULT_OPTIONS.contentProcessor,
|
|
55
59
|
});
|
|
56
60
|
},
|
|
57
61
|
});
|
|
58
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg-options.js","sourceRoot":"","sources":["../../../../../projects/core/components/svg/svg-options.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    FactoryProvider,\n    inject,\n    InjectionToken,\n    Optional,\n    Provider,\n    SkipSelf,\n} from '@angular/core';\nimport {\n    TuiHandler,\n    tuiIsString,\n    TuiSafeHtml,\n    TuiStringHandler,\n    tuiSvgLinearGradientProcessor,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_DEFAULT_ICONS_PLACE,\n    TUI_ICONS_PATH,\n    TUI_ICONS_PLACE,\n    TUI_SVG_CONTENT_PROCESSOR,\n    TUI_SVG_SRC_PROCESSOR,\n} from '@taiga-ui/core/tokens';\nimport {tuiIconsPathFactory} from '@taiga-ui/core/utils';\nimport {identity} from 'rxjs';\n\nimport {TUI_DEPRECATED_ICONS} from './deprecated-icons';\n\nexport interface TuiSvgOptions {\n    readonly iconsPlace: string;\n    readonly path: TuiStringHandler<string>;\n    readonly deprecated: TuiStringHandler<string>;\n    readonly srcProcessor: TuiHandler<TuiSafeHtml, TuiSafeHtml>;\n    readonly contentProcessor: TuiHandler<TuiSafeHtml, TuiSafeHtml>;\n}\n\nexport type TuiSvgInterceptorHandler =\n    | ((src: TuiSafeHtml, options: TuiSvgOptions) => TuiSafeHtml)\n    | ((src: TuiSafeHtml) => TuiSafeHtml);\n\nexport const TUI_SVG_DEFAULT_OPTIONS: TuiSvgOptions = {\n    iconsPlace: TUI_DEFAULT_ICONS_PLACE,\n    path: tuiIconsPathFactory(TUI_DEFAULT_ICONS_PLACE),\n    srcProcessor: identity,\n    contentProcessor: tuiSvgLinearGradientProcessor,\n    deprecated: src => {\n        const oldIcon = src.replace(`Large`, ``).replace(`Outline`, ``);\n        const newIcon = TUI_DEPRECATED_ICONS[oldIcon];\n\n        return newIcon\n            ? `${oldIcon}/(Large|Outline) is deprecated, use ${newIcon}/(Large|Outline) instead`\n            : ``;\n    },\n};\n\n/**\n * SVG component options\n */\nexport const TUI_SVG_OPTIONS = new InjectionToken<TuiSvgOptions>(`[TUI_SVG_OPTIONS]`, {\n    factory: () => ({\n        iconsPlace: inject(TUI_ICONS_PLACE),\n        path: inject(TUI_ICONS_PATH),\n        deprecated: TUI_SVG_DEFAULT_OPTIONS.deprecated,\n        srcProcessor: inject(TUI_SVG_SRC_PROCESSOR),\n        contentProcessor: inject(TUI_SVG_CONTENT_PROCESSOR),\n    }),\n});\n\nexport const TUI_SVG_SRC_INTERCEPTORS = new InjectionToken<TuiSvgInterceptorHandler>(\n    `[TUI_SVG_SRC_INTERCEPTORS]`,\n);\n\nexport function tuiSvgSrcInterceptors(interceptor: TuiSvgInterceptorHandler): Provider {\n    return {\n        provide: TUI_SVG_SRC_INTERCEPTORS,\n        useValue: interceptor,\n        multi: true,\n    };\n}\n\nexport const tuiSvgOptionsProvider: (\n    options: Partial<Omit<TuiSvgOptions, 'path'>> & {\n        path?: TuiSvgOptions['path'] | string;\n    },\n) => FactoryProvider = options => ({\n    provide: TUI_SVG_OPTIONS,\n    deps: [\n        [new SkipSelf(), new Optional(), TUI_SVG_OPTIONS],\n        [new Optional(), TUI_ICONS_PLACE],\n        [new Optional(), TUI_ICONS_PATH],\n        [new Optional(), TUI_SVG_SRC_PROCESSOR],\n        [new Optional(), TUI_SVG_CONTENT_PROCESSOR],\n    ],\n    useFactory: (\n        fallback: TuiSvgOptions | null,\n        iconsPlace: string | null,\n        path: TuiSvgOptions['path'] | null,\n        srcProcessor: TuiSvgOptions['srcProcessor'] | null,\n        contentProcessor: TuiSvgOptions['contentProcessor'] | null,\n    ): TuiSvgOptions => ({\n        iconsPlace:\n            options.iconsPlace ??\n            fallback?.iconsPlace ??\n            iconsPlace ??\n            TUI_SVG_DEFAULT_OPTIONS.iconsPlace,\n        path: tuiIsString(options.path)\n            ? tuiIconsPathFactory(options.path)\n            : options.path ?? fallback?.path ?? path ?? TUI_SVG_DEFAULT_OPTIONS.path,\n        deprecated:\n            options.deprecated ??\n            fallback?.deprecated ??\n            TUI_SVG_DEFAULT_OPTIONS.deprecated,\n        srcProcessor:\n            options.srcProcessor ??\n            fallback?.srcProcessor ??\n            srcProcessor ??\n            TUI_SVG_DEFAULT_OPTIONS.srcProcessor,\n        contentProcessor:\n            options.contentProcessor ??\n            fallback?.contentProcessor ??\n            contentProcessor ??\n            TUI_SVG_DEFAULT_OPTIONS.contentProcessor,\n    }),\n});\n"]}
|
|
@@ -10,7 +10,7 @@ import { TUI_SANITIZER } from '@taiga-ui/core/tokens';
|
|
|
10
10
|
import { tuiIsPresumedHTMLString } from '@taiga-ui/core/utils/miscellaneous';
|
|
11
11
|
import { of, ReplaySubject } from 'rxjs';
|
|
12
12
|
import { catchError, map, startWith, switchMap } from 'rxjs/operators';
|
|
13
|
-
import { TUI_SVG_OPTIONS, TUI_SVG_SRC_INTERCEPTORS } from './svg-options';
|
|
13
|
+
import { TUI_SVG_OPTIONS, TUI_SVG_SRC_INTERCEPTORS, } from './svg-options';
|
|
14
14
|
import * as i0 from "@angular/core";
|
|
15
15
|
import * as i1 from "@taiga-ui/cdk";
|
|
16
16
|
import * as i2 from "@angular/common";
|
|
@@ -46,7 +46,7 @@ export class TuiSvgComponent {
|
|
|
46
46
|
var _a;
|
|
47
47
|
const deprecated = this.options.deprecated(String(src));
|
|
48
48
|
ngDevMode && tuiAssert.assert(!deprecated, deprecated);
|
|
49
|
-
this.icon = ((_a = this.srcInterceptors) !== null && _a !== void 0 ? _a : []).reduce((newSrc, interceptor) => interceptor(newSrc), this.options.srcProcessor(src));
|
|
49
|
+
this.icon = ((_a = this.srcInterceptors) !== null && _a !== void 0 ? _a : []).reduce((newSrc, interceptor) => interceptor(newSrc, this.options), this.options.srcProcessor(src));
|
|
50
50
|
this.src$.next();
|
|
51
51
|
}
|
|
52
52
|
get src() {
|
|
@@ -76,7 +76,8 @@ export class TuiSvgComponent {
|
|
|
76
76
|
return this.isUrl || this.isCrossDomain;
|
|
77
77
|
}
|
|
78
78
|
get isUrl() {
|
|
79
|
-
return tuiIsString(this.icon) &&
|
|
79
|
+
return (tuiIsString(this.icon) &&
|
|
80
|
+
this.icon.replace(TUI_CACHE_BUSTING_PAYLOAD, '').endsWith('.svg'));
|
|
80
81
|
}
|
|
81
82
|
get isSrc() {
|
|
82
83
|
return tuiIsString(this.icon) && tuiIsPresumedHTMLString(this.icon);
|
|
@@ -153,7 +154,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
153
154
|
}] }, { type: undefined, decorators: [{
|
|
154
155
|
type: Inject,
|
|
155
156
|
args: [TUI_SVG_OPTIONS]
|
|
156
|
-
}] }, { type:
|
|
157
|
+
}] }, { type: undefined, decorators: [{
|
|
157
158
|
type: Optional
|
|
158
159
|
}, {
|
|
159
160
|
type: Inject,
|
|
@@ -178,4 +179,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
178
179
|
}] }]; }, propDecorators: { src: [{
|
|
179
180
|
type: Input
|
|
180
181
|
}], resolveName: [] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/svg/svg.component.ts","../../../../../projects/core/components/svg/svg.template.html"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    Inject,\n    Input,\n    Optional,\n    Sanitizer,\n    SecurityContext,\n} from '@angular/core';\nimport {DomSanitizer, SafeHtml} from '@angular/platform-browser';\nimport {WINDOW} from '@ng-web-apis/common';\nimport {\n    tuiAssert,\n    tuiGetDocumentOrShadowRoot,\n    TuiHandler,\n    tuiIsString,\n    tuiPure,\n    tuiRequiredSetter,\n    TuiSafeHtml,\n    TuiStaticRequestService,\n    TuiStringHandler,\n} from '@taiga-ui/cdk';\nimport {TUI_CACHE_BUSTING_PAYLOAD, TUI_ICON_ERROR} from '@taiga-ui/core/constants';\nimport {TuiIconError} from '@taiga-ui/core/interfaces';\nimport {TuiSvgService} from '@taiga-ui/core/services';\nimport {TUI_SANITIZER} from '@taiga-ui/core/tokens';\nimport {tuiIsPresumedHTMLString} from '@taiga-ui/core/utils/miscellaneous';\nimport {Observable, of, ReplaySubject} from 'rxjs';\nimport {catchError, map, startWith, switchMap} from 'rxjs/operators';\n\nimport {TUI_SVG_OPTIONS, TUI_SVG_SRC_INTERCEPTORS, TuiSvgOptions} from './svg-options';\n\nconst UNDEFINED_NAMED_ICON = 'Attempted to use undefined named icon';\nconst MISSING_EXTERNAL_ICON = 'External icon is missing on the given URL';\nconst FAILED_EXTERNAL_ICON = 'Failed to load external SVG';\n\n// TODO: Consider moving to CDK along with SvgService and SvgDefsHostComponent\n@Component({\n    selector: 'tui-svg',\n    templateUrl: './svg.template.html',\n    styleUrls: ['./svg.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiSvgComponent {\n    private readonly src$ = new ReplaySubject<void>(1);\n    private icon: TuiSafeHtml = '';\n\n    readonly innerHTML$: Observable<SafeHtml>;\n\n    constructor(\n        @Inject(DOCUMENT) private readonly doc: Document,\n        @Inject(WINDOW) private readonly win: Window,\n        @Inject(TUI_SVG_OPTIONS) private readonly options: TuiSvgOptions,\n        @Optional()\n        @Inject(TUI_SVG_SRC_INTERCEPTORS)\n        private readonly srcInterceptors: Array<\n            TuiHandler<TuiSafeHtml, TuiSafeHtml>\n        > | null,\n        @Optional()\n        @Inject(TUI_SANITIZER)\n        private readonly tuiSanitizer: Sanitizer | null,\n        @Inject(TuiSvgService) private readonly svgService: TuiSvgService,\n        @Inject(TuiStaticRequestService)\n        private readonly staticRequestService: TuiStaticRequestService,\n        @Inject(DomSanitizer) private readonly sanitizer: DomSanitizer,\n        @Inject(ElementRef) private readonly el: ElementRef<Element>,\n    ) {\n        this.innerHTML$ = this.src$.pipe(\n            switchMap(() => {\n                if (tuiIsString(this.icon)) {\n                    return this.isExternal\n                        ? this.getExternalIcon(this.icon)\n                        : of(this.getSafeHtml(this.icon));\n                }\n\n                return of(this.icon);\n            }),\n            startWith(''),\n        );\n    }\n\n    @Input()\n    @tuiRequiredSetter()\n    set src(src: TuiSafeHtml) {\n        const deprecated = this.options.deprecated(String(src));\n\n        ngDevMode && tuiAssert.assert(!deprecated, deprecated);\n\n        this.icon = (this.srcInterceptors ?? []).reduce(\n            (newSrc: TuiSafeHtml, interceptor) => interceptor(newSrc),\n            this.options.srcProcessor(src),\n        );\n\n        this.src$.next();\n    }\n\n    get src(): TuiSafeHtml {\n        return this.icon;\n    }\n\n    get use(): string {\n        if (tuiIsString(this.icon)) {\n            return this.icon.includes('.svg#')\n                ? this.icon\n                : this.resolveName(this.icon, this.options.path);\n        }\n\n        return '';\n    }\n\n    get isInnerHTML(): boolean {\n        return (\n            !tuiIsString(this.icon) ||\n            this.isSrc ||\n            this.isExternal ||\n            (this.isName && this.isShadowDOM)\n        );\n    }\n\n    private get isShadowDOM(): boolean {\n        return tuiGetDocumentOrShadowRoot(this.el.nativeElement) !== this.doc;\n    }\n\n    private get isUse(): boolean {\n        return this.use.replace(TUI_CACHE_BUSTING_PAYLOAD, '').includes('.svg#');\n    }\n\n    private get isExternal(): boolean {\n        return this.isUrl || this.isCrossDomain;\n    }\n\n    private get isUrl(): boolean {\n        return tuiIsString(this.icon) && this.icon.endsWith('.svg');\n    }\n\n    private get isSrc(): boolean {\n        return tuiIsString(this.icon) && tuiIsPresumedHTMLString(this.icon);\n    }\n\n    private get isName(): boolean {\n        return !this.isUrl && !this.isUse && !this.isSrc;\n    }\n\n    private get isCrossDomain(): boolean {\n        const {use, isUse, win} = this;\n\n        return (\n            isUse && use.startsWith('http') && !!win.origin && !use.startsWith(win.origin)\n        );\n    }\n\n    onError(message: string = MISSING_EXTERNAL_ICON): void {\n        const {icon} = this;\n        const event = new CustomEvent<TuiIconError>(TUI_ICON_ERROR, {\n            bubbles: true,\n            detail: {\n                message,\n                icon: icon as string,\n            },\n        });\n\n        ngDevMode && tuiAssert.assert(false, message, icon);\n        this.el.nativeElement.dispatchEvent(event);\n    }\n\n    @tuiPure\n    private resolveName(name: string, iconsPath: TuiStringHandler<string>): string {\n        return iconsPath(name);\n    }\n\n    private getSafeHtml(src: string): SafeHtml {\n        return this.isSrc ? this.sanitize(src) : this.process(src);\n    }\n\n    private process(src: string): SafeHtml {\n        const icon = this.svgService.getOriginal(src);\n\n        if (this.isName && !icon && !!src) {\n            this.onError(UNDEFINED_NAMED_ICON);\n        }\n\n        // Empty line for innerHTML when icon is shown through USE tag\n        return !this.isShadowDOM || !this.isName ? '' : this.sanitize(icon || '');\n    }\n\n    private sanitize(src: TuiSafeHtml): TuiSafeHtml {\n        src = this.options.contentProcessor(src);\n\n        return this.tuiSanitizer && tuiIsString(src)\n            ? this.sanitizer.bypassSecurityTrustHtml(\n                  this.tuiSanitizer.sanitize(SecurityContext.HTML, src) || '',\n              )\n            : src;\n    }\n\n    private getExternalIcon(src: string): Observable<SafeHtml> {\n        const url = src.includes('.svg') ? src : this.use;\n\n        return this.staticRequestService.request(url).pipe(\n            catchError(() => {\n                this.onError(FAILED_EXTERNAL_ICON);\n\n                return of('');\n            }),\n            map(response =>\n                this.sanitize(response.replace('<svg', '<svg focusable=\"false\"')),\n            ),\n        );\n    }\n}\n","<ng-container *tuiLet=\"innerHTML$ | async as innerHTML\">\n    <div\n        *ngIf=\"isInnerHTML; else useTemplate\"\n        class=\"t-src\"\n        [innerHTML]=\"innerHTML\"\n    ></div>\n    <ng-template #useTemplate>\n        <svg\n            version=\"1.1\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            focusable=\"false\"\n            width=\"100%\"\n            height=\"100%\"\n            class=\"t-svg\"\n            (error)=\"onError()\"\n        >\n            <use [attr.xlink:href]=\"use\"></use>\n        </svg>\n    </ng-template>\n</ng-container>\n"]}
|
|
182
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"svg.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/svg/svg.component.ts","../../../../../projects/core/components/svg/svg.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,iBAAiB,CAAC;AACzC,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EACL,QAAQ,EAER,eAAe,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,YAAY,EAAW,MAAM,2BAA2B,CAAC;AACjE,OAAO,EAAC,MAAM,EAAC,MAAM,qBAAqB,CAAC;AAC3C,OAAO,EACH,SAAS,EACT,0BAA0B,EAC1B,WAAW,EACX,OAAO,EACP,iBAAiB,EAEjB,uBAAuB,GAE1B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,yBAAyB,EAAE,cAAc,EAAC,MAAM,0BAA0B,CAAC;AAEnF,OAAO,EAAC,aAAa,EAAC,MAAM,yBAAyB,CAAC;AACtD,OAAO,EAAC,aAAa,EAAC,MAAM,uBAAuB,CAAC;AACpD,OAAO,EAAC,uBAAuB,EAAC,MAAM,oCAAoC,CAAC;AAC3E,OAAO,EAAa,EAAE,EAAE,aAAa,EAAC,MAAM,MAAM,CAAC;AACnD,OAAO,EAAC,UAAU,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAErE,OAAO,EACH,eAAe,EACf,wBAAwB,GAG3B,MAAM,eAAe,CAAC;;;;;;AAEvB,MAAM,oBAAoB,GAAG,uCAAuC,CAAC;AACrE,MAAM,qBAAqB,GAAG,2CAA2C,CAAC;AAC1E,MAAM,oBAAoB,GAAG,6BAA6B,CAAC;AAE3D,8EAA8E;AAO9E,MAAM,OAAO,eAAe;IAMxB,YACuC,GAAa,EACf,GAAW,EACF,OAAsB,EAG/C,eAA2D,EAG3D,YAA8B,EACP,UAAyB,EAEhD,oBAA6C,EACvB,SAAuB,EACzB,EAAuB;QAbzB,QAAG,GAAH,GAAG,CAAU;QACf,QAAG,GAAH,GAAG,CAAQ;QACF,YAAO,GAAP,OAAO,CAAe;QAG/C,oBAAe,GAAf,eAAe,CAA4C;QAG3D,iBAAY,GAAZ,YAAY,CAAkB;QACP,eAAU,GAAV,UAAU,CAAe;QAEhD,yBAAoB,GAApB,oBAAoB,CAAyB;QACvB,cAAS,GAAT,SAAS,CAAc;QACzB,OAAE,GAAF,EAAE,CAAqB;QAnB/C,SAAI,GAAG,IAAI,aAAa,CAAO,CAAC,CAAC,CAAC;QAC3C,SAAI,GAAgB,EAAE,CAAC;QAoB3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAC5B,SAAS,CAAC,GAAG,EAAE;YACX,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACxB,OAAO,IAAI,CAAC,UAAU;oBAClB,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC;oBACjC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;aACzC;YAED,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,EACF,SAAS,CAAC,EAAE,CAAC,CAChB,CAAC;IACN,CAAC;IAID,IAAI,GAAG,CAAC,GAAgB;;QACpB,MAAM,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;QAExD,SAAS,IAAI,SAAS,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAEvD,IAAI,CAAC,IAAI,GAAG,CAAC,MAAA,IAAI,CAAC,eAAe,mCAAI,EAAE,CAAC,CAAC,MAAM,CAC3C,CAAC,MAAM,EAAE,WAAW,EAAE,EAAE,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,EAC1D,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,GAAG,CAAC,CACjC,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,IAAI,GAAG;QACH,OAAO,IAAI,CAAC,IAAI,CAAC;IACrB,CAAC;IAED,IAAI,GAAG;QACH,IAAI,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAC9B,CAAC,CAAC,IAAI,CAAC,IAAI;gBACX,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SACxD;QAED,OAAO,EAAE,CAAC;IACd,CAAC;IAED,IAAI,WAAW;QACX,OAAO,CACH,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC;YACvB,IAAI,CAAC,KAAK;YACV,IAAI,CAAC,UAAU;YACf,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,WAAW,CAAC,CACpC,CAAC;IACN,CAAC;IAED,IAAY,WAAW;QACnB,OAAO,0BAA0B,CAAC,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC;IAC1E,CAAC;IAED,IAAY,KAAK;QACb,OAAO,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC7E,CAAC;IAED,IAAY,UAAU;QAClB,OAAO,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,aAAa,CAAC;IAC5C,CAAC;IAED,IAAY,KAAK;QACb,OAAO,CACH,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC;YACtB,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM,CAAC,CACpE,CAAC;IACN,CAAC;IAED,IAAY,KAAK;QACb,OAAO,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxE,CAAC;IAED,IAAY,MAAM;QACd,OAAO,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;IACrD,CAAC;IAED,IAAY,aAAa;QACrB,MAAM,EAAC,GAAG,EAAE,KAAK,EAAE,GAAG,EAAC,GAAG,IAAI,CAAC;QAE/B,OAAO,CACH,KAAK,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,MAAM,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,CACjF,CAAC;IACN,CAAC;IAED,OAAO,CAAC,UAAkB,qBAAqB;QAC3C,MAAM,EAAC,IAAI,EAAC,GAAG,IAAI,CAAC;QACpB,MAAM,KAAK,GAAG,IAAI,WAAW,CAAe,cAAc,EAAE;YACxD,OAAO,EAAE,IAAI;YACb,MAAM,EAAE;gBACJ,OAAO;gBACP,IAAI,EAAE,IAAc;aACvB;SACJ,CAAC,CAAC;QAEH,SAAS,IAAI,SAAS,CAAC,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;QACpD,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC/C,CAAC;IAGO,WAAW,CAAC,IAAY,EAAE,SAAmC;QACjE,OAAO,SAAS,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAEO,WAAW,CAAC,GAAW;QAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC/D,CAAC;IAEO,OAAO,CAAC,GAAW;QACvB,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAE9C,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,GAAG,EAAE;YAC/B,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;SACtC;QAED,8DAA8D;QAC9D,OAAO,CAAC,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC;IAC9E,CAAC;IAEO,QAAQ,CAAC,GAAgB;QAC7B,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;QAEzC,OAAO,IAAI,CAAC,YAAY,IAAI,WAAW,CAAC,GAAG,CAAC;YACxC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAClC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,eAAe,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,CAC9D;YACH,CAAC,CAAC,GAAG,CAAC;IACd,CAAC;IAEO,eAAe,CAAC,GAAW;QAC/B,MAAM,GAAG,GAAG,GAAG,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;QAElD,OAAO,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,IAAI,CAC9C,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;YAEnC,OAAO,EAAE,CAAC,EAAE,CAAC,CAAC;QAClB,CAAC,CAAC,EACF,GAAG,CAAC,QAAQ,CAAC,EAAE,CACX,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,EAAE,wBAAwB,CAAC,CAAC,CACpE,CACJ,CAAC;IACN,CAAC;;6GAtKQ,eAAe,kBAOZ,QAAQ,aACR,MAAM,aACN,eAAe,aAEf,wBAAwB,6BAGxB,aAAa,6BAEb,aAAa,aACb,uBAAuB,aAEvB,YAAY,aACZ,UAAU;iGApBb,eAAe,uECjD5B,soBAqBA;ADkEI;IADC,iBAAiB,EAAE;0CAYnB;AA2ED;IADC,OAAO;kDAGP;4FA9HQ,eAAe;kBAN3B,SAAS;mBAAC;oBACP,QAAQ,EAAE,SAAS;oBACnB,WAAW,EAAE,qBAAqB;oBAClC,SAAS,EAAE,CAAC,kBAAkB,CAAC;oBAC/B,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;0DAQ+C,QAAQ;0BAA/C,MAAM;2BAAC,QAAQ;8BACsB,MAAM;0BAA3C,MAAM;2BAAC,MAAM;;0BACb,MAAM;2BAAC,eAAe;;0BACtB,QAAQ;;0BACR,MAAM;2BAAC,wBAAwB;;0BAE/B,QAAQ;;0BACR,MAAM;2BAAC,aAAa;;0BAEpB,MAAM;2BAAC,aAAa;;0BACpB,MAAM;2BAAC,uBAAuB;;0BAE9B,MAAM;2BAAC,YAAY;;0BACnB,MAAM;2BAAC,UAAU;4CAkBlB,GAAG;sBAFN,KAAK;gBAwFE,WAAW","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    Inject,\n    Input,\n    Optional,\n    Sanitizer,\n    SecurityContext,\n} from '@angular/core';\nimport {DomSanitizer, SafeHtml} from '@angular/platform-browser';\nimport {WINDOW} from '@ng-web-apis/common';\nimport {\n    tuiAssert,\n    tuiGetDocumentOrShadowRoot,\n    tuiIsString,\n    tuiPure,\n    tuiRequiredSetter,\n    TuiSafeHtml,\n    TuiStaticRequestService,\n    TuiStringHandler,\n} from '@taiga-ui/cdk';\nimport {TUI_CACHE_BUSTING_PAYLOAD, TUI_ICON_ERROR} from '@taiga-ui/core/constants';\nimport {TuiIconError} from '@taiga-ui/core/interfaces';\nimport {TuiSvgService} from '@taiga-ui/core/services';\nimport {TUI_SANITIZER} from '@taiga-ui/core/tokens';\nimport {tuiIsPresumedHTMLString} from '@taiga-ui/core/utils/miscellaneous';\nimport {Observable, of, ReplaySubject} from 'rxjs';\nimport {catchError, map, startWith, switchMap} from 'rxjs/operators';\n\nimport {\n    TUI_SVG_OPTIONS,\n    TUI_SVG_SRC_INTERCEPTORS,\n    TuiSvgInterceptorHandler,\n    TuiSvgOptions,\n} from './svg-options';\n\nconst UNDEFINED_NAMED_ICON = 'Attempted to use undefined named icon';\nconst MISSING_EXTERNAL_ICON = 'External icon is missing on the given URL';\nconst FAILED_EXTERNAL_ICON = 'Failed to load external SVG';\n\n// TODO: Consider moving to CDK along with SvgService and SvgDefsHostComponent\n@Component({\n    selector: 'tui-svg',\n    templateUrl: './svg.template.html',\n    styleUrls: ['./svg.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiSvgComponent {\n    private readonly src$ = new ReplaySubject<void>(1);\n    private icon: TuiSafeHtml = '';\n\n    readonly innerHTML$: Observable<SafeHtml>;\n\n    constructor(\n        @Inject(DOCUMENT) private readonly doc: Document,\n        @Inject(WINDOW) private readonly win: Window,\n        @Inject(TUI_SVG_OPTIONS) private readonly options: TuiSvgOptions,\n        @Optional()\n        @Inject(TUI_SVG_SRC_INTERCEPTORS)\n        private readonly srcInterceptors: readonly TuiSvgInterceptorHandler[] | null,\n        @Optional()\n        @Inject(TUI_SANITIZER)\n        private readonly tuiSanitizer: Sanitizer | null,\n        @Inject(TuiSvgService) private readonly svgService: TuiSvgService,\n        @Inject(TuiStaticRequestService)\n        private readonly staticRequestService: TuiStaticRequestService,\n        @Inject(DomSanitizer) private readonly sanitizer: DomSanitizer,\n        @Inject(ElementRef) private readonly el: ElementRef<Element>,\n    ) {\n        this.innerHTML$ = this.src$.pipe(\n            switchMap(() => {\n                if (tuiIsString(this.icon)) {\n                    return this.isExternal\n                        ? this.getExternalIcon(this.icon)\n                        : of(this.getSafeHtml(this.icon));\n                }\n\n                return of(this.icon);\n            }),\n            startWith(''),\n        );\n    }\n\n    @Input()\n    @tuiRequiredSetter()\n    set src(src: TuiSafeHtml) {\n        const deprecated = this.options.deprecated(String(src));\n\n        ngDevMode && tuiAssert.assert(!deprecated, deprecated);\n\n        this.icon = (this.srcInterceptors ?? []).reduce(\n            (newSrc, interceptor) => interceptor(newSrc, this.options),\n            this.options.srcProcessor(src),\n        );\n\n        this.src$.next();\n    }\n\n    get src(): TuiSafeHtml {\n        return this.icon;\n    }\n\n    get use(): string {\n        if (tuiIsString(this.icon)) {\n            return this.icon.includes('.svg#')\n                ? this.icon\n                : this.resolveName(this.icon, this.options.path);\n        }\n\n        return '';\n    }\n\n    get isInnerHTML(): boolean {\n        return (\n            !tuiIsString(this.icon) ||\n            this.isSrc ||\n            this.isExternal ||\n            (this.isName && this.isShadowDOM)\n        );\n    }\n\n    private get isShadowDOM(): boolean {\n        return tuiGetDocumentOrShadowRoot(this.el.nativeElement) !== this.doc;\n    }\n\n    private get isUse(): boolean {\n        return this.use.replace(TUI_CACHE_BUSTING_PAYLOAD, '').includes('.svg#');\n    }\n\n    private get isExternal(): boolean {\n        return this.isUrl || this.isCrossDomain;\n    }\n\n    private get isUrl(): boolean {\n        return (\n            tuiIsString(this.icon) &&\n            this.icon.replace(TUI_CACHE_BUSTING_PAYLOAD, '').endsWith('.svg')\n        );\n    }\n\n    private get isSrc(): boolean {\n        return tuiIsString(this.icon) && tuiIsPresumedHTMLString(this.icon);\n    }\n\n    private get isName(): boolean {\n        return !this.isUrl && !this.isUse && !this.isSrc;\n    }\n\n    private get isCrossDomain(): boolean {\n        const {use, isUse, win} = this;\n\n        return (\n            isUse && use.startsWith('http') && !!win.origin && !use.startsWith(win.origin)\n        );\n    }\n\n    onError(message: string = MISSING_EXTERNAL_ICON): void {\n        const {icon} = this;\n        const event = new CustomEvent<TuiIconError>(TUI_ICON_ERROR, {\n            bubbles: true,\n            detail: {\n                message,\n                icon: icon as string,\n            },\n        });\n\n        ngDevMode && tuiAssert.assert(false, message, icon);\n        this.el.nativeElement.dispatchEvent(event);\n    }\n\n    @tuiPure\n    private resolveName(name: string, iconsPath: TuiStringHandler<string>): string {\n        return iconsPath(name);\n    }\n\n    private getSafeHtml(src: string): SafeHtml {\n        return this.isSrc ? this.sanitize(src) : this.process(src);\n    }\n\n    private process(src: string): SafeHtml {\n        const icon = this.svgService.getOriginal(src);\n\n        if (this.isName && !icon && !!src) {\n            this.onError(UNDEFINED_NAMED_ICON);\n        }\n\n        // Empty line for innerHTML when icon is shown through USE tag\n        return !this.isShadowDOM || !this.isName ? '' : this.sanitize(icon || '');\n    }\n\n    private sanitize(src: TuiSafeHtml): TuiSafeHtml {\n        src = this.options.contentProcessor(src);\n\n        return this.tuiSanitizer && tuiIsString(src)\n            ? this.sanitizer.bypassSecurityTrustHtml(\n                  this.tuiSanitizer.sanitize(SecurityContext.HTML, src) || '',\n              )\n            : src;\n    }\n\n    private getExternalIcon(src: string): Observable<SafeHtml> {\n        const url = src.includes('.svg') ? src : this.use;\n\n        return this.staticRequestService.request(url).pipe(\n            catchError(() => {\n                this.onError(FAILED_EXTERNAL_ICON);\n\n                return of('');\n            }),\n            map(response =>\n                this.sanitize(response.replace('<svg', '<svg focusable=\"false\"')),\n            ),\n        );\n    }\n}\n","<ng-container *tuiLet=\"innerHTML$ | async as innerHTML\">\n    <div\n        *ngIf=\"isInnerHTML; else useTemplate\"\n        class=\"t-src\"\n        [innerHTML]=\"innerHTML\"\n    ></div>\n    <ng-template #useTemplate>\n        <svg\n            version=\"1.1\"\n            xmlns=\"http://www.w3.org/2000/svg\"\n            xmlns:xlink=\"http://www.w3.org/1999/xlink\"\n            focusable=\"false\"\n            width=\"100%\"\n            height=\"100%\"\n            class=\"t-svg\"\n            (error)=\"onError()\"\n        >\n            <use [attr.xlink:href]=\"use\"></use>\n        </svg>\n    </ng-template>\n</ng-container>\n"]}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const TUI_DEFAULT_ICONS_PLACE = `assets/taiga-ui/icons`;
|
|
2
3
|
/**
|
|
3
4
|
* Path to icons
|
|
4
5
|
* @deprecated Use {@link TUI_SVG_OPTIONS} instead
|
|
5
6
|
*/
|
|
6
7
|
export const TUI_ICONS_PLACE = new InjectionToken(`[TUI_ICONS_PLACE]`, {
|
|
7
|
-
factory: () =>
|
|
8
|
+
factory: () => TUI_DEFAULT_ICONS_PLACE,
|
|
8
9
|
});
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWNvbi1wbGFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvdG9rZW5zL2ljb24tcGxhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUU3QyxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyx1QkFBZ0MsQ0FBQztBQUV4RTs7O0dBR0c7QUFDSCxNQUFNLENBQUMsTUFBTSxlQUFlLEdBQTJCLElBQUksY0FBYyxDQUNyRSxtQkFBbUIsRUFDbkI7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsdUJBQXVCO0NBQ3pDLENBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVFVJX0RFRkFVTFRfSUNPTlNfUExBQ0UgPSBgYXNzZXRzL3RhaWdhLXVpL2ljb25zYCBhcyBjb25zdDtcblxuLyoqXG4gKiBQYXRoIHRvIGljb25zXG4gKiBAZGVwcmVjYXRlZCBVc2Uge0BsaW5rIFRVSV9TVkdfT1BUSU9OU30gaW5zdGVhZFxuICovXG5leHBvcnQgY29uc3QgVFVJX0lDT05TX1BMQUNFOiBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+ID0gbmV3IEluamVjdGlvblRva2VuPHN0cmluZz4oXG4gICAgYFtUVUlfSUNPTlNfUExBQ0VdYCxcbiAgICB7XG4gICAgICAgIGZhY3Rvcnk6ICgpID0+IFRVSV9ERUZBVUxUX0lDT05TX1BMQUNFLFxuICAgIH0sXG4pO1xuIl19
|
|
@@ -3,7 +3,7 @@ import { DOCUMENT, CommonModule } from '@angular/common';
|
|
|
3
3
|
import * as i0 from '@angular/core';
|
|
4
4
|
import { Component, ChangeDetectionStrategy, ViewEncapsulation, Inject, NgModule } from '@angular/core';
|
|
5
5
|
import * as i3 from '@taiga-ui/cdk';
|
|
6
|
-
import { TUI_DIALOGS, TUI_IS_MOBILE, TUI_VERSION, TuiDragModule, TuiDropdownHostModule, TuiDialogHostModule, TuiAlertHostModule } from '@taiga-ui/cdk';
|
|
6
|
+
import { TUI_DIALOGS, TUI_IS_MOBILE, TUI_IS_IOS, TUI_IS_ANDROID, TUI_VERSION, TuiDragModule, TuiDropdownHostModule, TuiDialogHostModule, TuiAlertHostModule } from '@taiga-ui/cdk';
|
|
7
7
|
import { TUI_IS_MOBILE_RES_PROVIDER } from '@taiga-ui/core/providers';
|
|
8
8
|
import { TUI_ANIMATIONS_DURATION, TUI_IS_MOBILE_RES, TUI_THEME } from '@taiga-ui/core/tokens';
|
|
9
9
|
import * as i6 from 'rxjs';
|
|
@@ -18,19 +18,21 @@ import { TuiHintsHostModule } from '@taiga-ui/core/components/hints-host';
|
|
|
18
18
|
import { EventPluginsModule } from '@tinkoff/ng-event-plugins';
|
|
19
19
|
|
|
20
20
|
class TuiRootComponent {
|
|
21
|
-
constructor(duration, dialogs, isMobile, isMobileRes$, { body }, theme) {
|
|
21
|
+
constructor(duration, dialogs, isMobile, isMobileRes$, isIOS, isAndroid, { body }, theme) {
|
|
22
22
|
this.duration = duration;
|
|
23
23
|
this.dialogs = dialogs;
|
|
24
24
|
this.isMobile = isMobile;
|
|
25
25
|
this.isMobileRes$ = isMobileRes$;
|
|
26
|
+
this.isIOS = isIOS;
|
|
27
|
+
this.isAndroid = isAndroid;
|
|
26
28
|
this.scrollbars$ = this.dialogs.length && !this.isMobile
|
|
27
29
|
? combineLatest([...this.dialogs]).pipe(map(dialogs => !dialogs.some(({ length }) => length)))
|
|
28
30
|
: of(!this.isMobile);
|
|
29
31
|
body.setAttribute('data-tui-theme', theme.toLowerCase());
|
|
30
32
|
}
|
|
31
33
|
}
|
|
32
|
-
TuiRootComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, deps: [{ token: TUI_ANIMATIONS_DURATION }, { token: TUI_DIALOGS }, { token: TUI_IS_MOBILE }, { token: TUI_IS_MOBILE_RES }, { token: DOCUMENT }, { token: TUI_THEME }], target: i0.ɵɵFactoryTarget.Component });
|
|
33
|
-
TuiRootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiRootComponent, selector: "tui-root", host: { attributes: { "data-tui-version": "3.
|
|
34
|
+
TuiRootComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, deps: [{ token: TUI_ANIMATIONS_DURATION }, { token: TUI_DIALOGS }, { token: TUI_IS_MOBILE }, { token: TUI_IS_MOBILE_RES }, { token: TUI_IS_IOS }, { token: TUI_IS_ANDROID }, { token: DOCUMENT }, { token: TUI_THEME }], target: i0.ɵɵFactoryTarget.Component });
|
|
35
|
+
TuiRootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiRootComponent, selector: "tui-root", host: { attributes: { "data-tui-version": "3.31.0" }, listeners: { "$.class._mobile": "isMobileRes$" }, properties: { "style.--tui-duration.ms": "duration", "class._ios": "isIOS", "class._android": "isAndroid" } }, providers: [TUI_IS_MOBILE_RES_PROVIDER], ngImport: i0, template: "<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n></tui-scroll-controls>\n<tui-svg-defs-host></tui-svg-defs-host>\n<tui-dropdown-host>\n <div class=\"t-root-content\">\n <ng-content></ng-content>\n </div>\n <ng-content select=\"tuiOverContent\"></ng-content>\n <tui-dialog-host></tui-dialog-host>\n <ng-content select=\"tuiOverDialogs\"></ng-content>\n <tui-alert-host></tui-alert-host>\n <ng-content select=\"tuiOverAlerts\"></ng-content>\n</tui-dropdown-host>\n<ng-content select=\"tuiOverPortals\"></ng-content>\n<tui-hints-host></tui-hints-host>\n<ng-content select=\"tuiOverHints\"></ng-content>\n", styles: ["@keyframes tuiPresent{to{content:\"1\"}}html,.tui-zero-scrollbar{scrollbar-width:none;-ms-overflow-style:none}html::-webkit-scrollbar,.tui-zero-scrollbar::-webkit-scrollbar,html::-webkit-scrollbar-thumb,.tui-zero-scrollbar::-webkit-scrollbar-thumb{background:transparent;width:0;height:0}body{font:var(--tui-font-text-s);color:var(--tui-text-01);margin:0}tui-root{position:relative;display:block;flex:1;-webkit-tap-highlight-color:transparent}tui-root>.t-root-scrollbar{position:fixed;top:0;left:0;bottom:0;right:0;margin:0}.t-root-content{position:relative;z-index:0;height:100%}\n"], components: [{ type: i1.TuiScrollControlsComponent, selector: "tui-scroll-controls" }, { type: i2.TuiSvgDefsHostComponent, selector: "tui-svg-defs-host" }, { type: i3.TuiDropdownHostComponent, selector: "tui-dropdown-host" }, { type: i3.TuiDialogHostComponent, selector: "tui-dialog-host" }, { type: i3.TuiAlertHostComponent, selector: "tui-alert-host" }, { type: i4.TuiHintsHostComponent, selector: "tui-hints-host" }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i5.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.Default, encapsulation: i0.ViewEncapsulation.None });
|
|
34
36
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, decorators: [{
|
|
35
37
|
type: Component,
|
|
36
38
|
args: [{
|
|
@@ -45,6 +47,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
45
47
|
host: {
|
|
46
48
|
'data-tui-version': TUI_VERSION,
|
|
47
49
|
'[style.--tui-duration.ms]': 'duration',
|
|
50
|
+
'[class._ios]': 'isIOS',
|
|
51
|
+
'[class._android]': 'isAndroid',
|
|
48
52
|
'($.class._mobile)': 'isMobileRes$',
|
|
49
53
|
},
|
|
50
54
|
}]
|
|
@@ -60,6 +64,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
60
64
|
}] }, { type: i6.Observable, decorators: [{
|
|
61
65
|
type: Inject,
|
|
62
66
|
args: [TUI_IS_MOBILE_RES]
|
|
67
|
+
}] }, { type: undefined, decorators: [{
|
|
68
|
+
type: Inject,
|
|
69
|
+
args: [TUI_IS_IOS]
|
|
70
|
+
}] }, { type: undefined, decorators: [{
|
|
71
|
+
type: Inject,
|
|
72
|
+
args: [TUI_IS_ANDROID]
|
|
63
73
|
}] }, { type: Document, decorators: [{
|
|
64
74
|
type: Inject,
|
|
65
75
|
args: [DOCUMENT]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-core-components-root.js","sources":["../../../projects/core/components/root/root.component.ts","../../../projects/core/components/root/root.template.html","../../../projects/core/components/root/root.module.ts","../../../projects/core/components/root/taiga-ui-core-components-root.ts"],"sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n Inject,\n ViewEncapsulation,\n} from '@angular/core';\nimport {TUI_DIALOGS
|
|
1
|
+
{"version":3,"file":"taiga-ui-core-components-root.js","sources":["../../../projects/core/components/root/root.component.ts","../../../projects/core/components/root/root.template.html","../../../projects/core/components/root/root.module.ts","../../../projects/core/components/root/taiga-ui-core-components-root.ts"],"sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n ChangeDetectionStrategy,\n Component,\n Inject,\n ViewEncapsulation,\n} from '@angular/core';\nimport {\n TUI_DIALOGS,\n TUI_IS_ANDROID,\n TUI_IS_IOS,\n TUI_IS_MOBILE,\n TUI_VERSION,\n} from '@taiga-ui/cdk';\nimport {TUI_IS_MOBILE_RES_PROVIDER} from '@taiga-ui/core/providers';\nimport {\n TUI_ANIMATIONS_DURATION,\n TUI_IS_MOBILE_RES,\n TUI_THEME,\n} from '@taiga-ui/core/tokens';\nimport {combineLatest, Observable, of} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\n@Component({\n selector: 'tui-root',\n templateUrl: './root.template.html',\n styleUrls: ['./root.style.less'],\n // So that we do not force OnPush on custom dialogs\n // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n changeDetection: ChangeDetectionStrategy.Default,\n providers: [TUI_IS_MOBILE_RES_PROVIDER],\n encapsulation: ViewEncapsulation.None,\n host: {\n 'data-tui-version': TUI_VERSION,\n '[style.--tui-duration.ms]': 'duration',\n '[class._ios]': 'isIOS',\n '[class._android]': 'isAndroid',\n '($.class._mobile)': 'isMobileRes$',\n },\n})\nexport class TuiRootComponent {\n readonly scrollbars$: Observable<boolean> =\n this.dialogs.length && !this.isMobile\n ? combineLatest([...this.dialogs]).pipe(\n map(dialogs => !dialogs.some(({length}) => length)),\n )\n : of(!this.isMobile);\n\n constructor(\n @Inject(TUI_ANIMATIONS_DURATION) readonly duration: number,\n @Inject(TUI_DIALOGS)\n readonly dialogs: ReadonlyArray<Observable<readonly unknown[]>>,\n @Inject(TUI_IS_MOBILE) private readonly isMobile: boolean,\n @Inject(TUI_IS_MOBILE_RES) readonly isMobileRes$: Observable<boolean>,\n @Inject(TUI_IS_IOS) readonly isIOS: boolean,\n @Inject(TUI_IS_ANDROID) readonly isAndroid: boolean,\n @Inject(DOCUMENT) {body}: Document,\n @Inject(TUI_THEME) theme: string,\n ) {\n body.setAttribute('data-tui-theme', theme.toLowerCase());\n }\n}\n","<tui-scroll-controls\n *ngIf=\"scrollbars$ | async\"\n class=\"t-root-scrollbar\"\n></tui-scroll-controls>\n<tui-svg-defs-host></tui-svg-defs-host>\n<tui-dropdown-host>\n <div class=\"t-root-content\">\n <ng-content></ng-content>\n </div>\n <ng-content select=\"tuiOverContent\"></ng-content>\n <tui-dialog-host></tui-dialog-host>\n <ng-content select=\"tuiOverDialogs\"></ng-content>\n <tui-alert-host></tui-alert-host>\n <ng-content select=\"tuiOverAlerts\"></ng-content>\n</tui-dropdown-host>\n<ng-content select=\"tuiOverPortals\"></ng-content>\n<tui-hints-host></tui-hints-host>\n<ng-content select=\"tuiOverHints\"></ng-content>\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {\n TuiAlertHostModule,\n TuiDialogHostModule,\n TuiDragModule,\n TuiDropdownHostModule,\n} from '@taiga-ui/cdk';\nimport {TuiHintsHostModule} from '@taiga-ui/core/components/hints-host';\nimport {TuiScrollControlsModule} from '@taiga-ui/core/components/scroll-controls';\nimport {TuiSvgDefsHostModule} from '@taiga-ui/core/internal/svg-defs-host';\nimport {EventPluginsModule} from '@tinkoff/ng-event-plugins';\n\nimport {TuiRootComponent} from './root.component';\n\n@NgModule({\n imports: [\n CommonModule,\n EventPluginsModule,\n TuiDragModule,\n TuiDropdownHostModule,\n TuiSvgDefsHostModule,\n TuiHintsHostModule,\n TuiDialogHostModule,\n TuiAlertHostModule,\n TuiScrollControlsModule,\n ],\n declarations: [TuiRootComponent],\n exports: [TuiRootComponent],\n})\nexport class TuiRootModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;MAwCa,gBAAgB,CAAA;AAQzB,IAAA,WAAA,CAC8C,QAAgB,EAEjD,OAAsD,EACvB,QAAiB,EACrB,YAAiC,EACxC,KAAc,EACV,SAAkB,EACjC,EAAC,IAAI,EAAW,EACf,KAAa,EAAA;QARU,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAQ;QAEjD,IAAO,CAAA,OAAA,GAAP,OAAO,CAA+C;QACvB,IAAQ,CAAA,QAAA,GAAR,QAAQ,CAAS;QACrB,IAAY,CAAA,YAAA,GAAZ,YAAY,CAAqB;QACxC,IAAK,CAAA,KAAA,GAAL,KAAK,CAAS;QACV,IAAS,CAAA,SAAA,GAAT,SAAS,CAAS;QAd9C,IAAW,CAAA,WAAA,GAChB,IAAI,CAAC,OAAO,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,QAAQ;AACjC,cAAE,aAAa,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CACjC,GAAG,CAAC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,EAAC,MAAM,EAAC,KAAK,MAAM,CAAC,CAAC,CACtD;cACD,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAazB,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;KAC5D;;AApBQ,gBAAA,CAAA,IAAA,GAAA,EAAA,CAAA,kBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,gBAAgB,EASb,IAAA,EAAA,CAAA,EAAA,KAAA,EAAA,uBAAuB,EACvB,EAAA,EAAA,KAAA,EAAA,WAAW,aAEX,aAAa,EAAA,EAAA,EAAA,KAAA,EACb,iBAAiB,EAAA,EAAA,EAAA,KAAA,EACjB,UAAU,EACV,EAAA,EAAA,KAAA,EAAA,cAAc,EACd,EAAA,EAAA,KAAA,EAAA,QAAQ,aACR,SAAS,EAAA,CAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,SAAA,EAAA,CAAA,CAAA;AAjBZ,gBAAA,CAAA,IAAA,GAAA,EAAA,CAAA,oBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,IAAA,EAAA,gBAAgB,EAVd,QAAA,EAAA,UAAA,EAAA,IAAA,EAAA,EAAA,UAAA,EAAA,EAAA,kBAAA,EAAA,QAAA,EAAA,EAAA,SAAA,EAAA,EAAA,iBAAA,EAAA,cAAA,EAAA,EAAA,UAAA,EAAA,EAAA,yBAAA,EAAA,UAAA,EAAA,YAAA,EAAA,OAAA,EAAA,gBAAA,EAAA,WAAA,EAAA,EAAA,EAAA,SAAA,EAAA,CAAC,0BAA0B,CAAC,0BC9B3C,gqBAkBA,EAAA,MAAA,EAAA,CAAA,wkBAAA,CAAA,EAAA,UAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,0BAAA,EAAA,QAAA,EAAA,qBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,uBAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,wBAAA,EAAA,QAAA,EAAA,mBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,sBAAA,EAAA,QAAA,EAAA,iBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,qBAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,EAAA,EAAA,IAAA,EAAA,EAAA,CAAA,qBAAA,EAAA,QAAA,EAAA,gBAAA,EAAA,CAAA,EAAA,UAAA,EAAA,CAAA,EAAA,IAAA,EAAA,EAAA,CAAA,IAAA,EAAA,QAAA,EAAA,QAAA,EAAA,MAAA,EAAA,CAAA,MAAA,EAAA,UAAA,EAAA,UAAA,CAAA,EAAA,CAAA,EAAA,KAAA,EAAA,EAAA,OAAA,EAAA,EAAA,CAAA,SAAA,EAAA,EAAA,eAAA,EAAA,EAAA,CAAA,uBAAA,CAAA,OAAA,EAAA,aAAA,EAAA,EAAA,CAAA,iBAAA,CAAA,IAAA,EAAA,CAAA,CAAA;4FDsBa,gBAAgB,EAAA,UAAA,EAAA,CAAA;kBAjB5B,SAAS;AAAC,YAAA,IAAA,EAAA,CAAA;AACP,oBAAA,QAAQ,EAAE,UAAU;AACpB,oBAAA,WAAW,EAAE,sBAAsB;oBACnC,SAAS,EAAE,CAAC,mBAAmB,CAAC;;;oBAGhC,eAAe,EAAE,uBAAuB,CAAC,OAAO;oBAChD,SAAS,EAAE,CAAC,0BAA0B,CAAC;oBACvC,aAAa,EAAE,iBAAiB,CAAC,IAAI;AACrC,oBAAA,IAAI,EAAE;AACF,wBAAA,kBAAkB,EAAE,WAAW;AAC/B,wBAAA,2BAA2B,EAAE,UAAU;AACvC,wBAAA,cAAc,EAAE,OAAO;AACvB,wBAAA,kBAAkB,EAAE,WAAW;AAC/B,wBAAA,mBAAmB,EAAE,cAAc;AACtC,qBAAA;AACJ,iBAAA,CAAA;;0BAUQ,MAAM;2BAAC,uBAAuB,CAAA;;0BAC9B,MAAM;2BAAC,WAAW,CAAA;;0BAElB,MAAM;2BAAC,aAAa,CAAA;;0BACpB,MAAM;2BAAC,iBAAiB,CAAA;;0BACxB,MAAM;2BAAC,UAAU,CAAA;;0BACjB,MAAM;2BAAC,cAAc,CAAA;8BACI,QAAQ,EAAA,UAAA,EAAA,CAAA;0BAAjC,MAAM;2BAAC,QAAQ,CAAA;;0BACf,MAAM;2BAAC,SAAS,CAAA;;;ME3BZ,aAAa,CAAA;;2GAAb,aAAa,EAAA,IAAA,EAAA,EAAA,EAAA,MAAA,EAAA,EAAA,CAAA,eAAA,CAAA,QAAA,EAAA,CAAA,CAAA;4GAAb,aAAa,EAAA,YAAA,EAAA,CAHP,gBAAgB,CAAA,EAAA,OAAA,EAAA,CAV3B,YAAY;QACZ,kBAAkB;QAClB,aAAa;QACb,qBAAqB;QACrB,oBAAoB;QACpB,kBAAkB;QAClB,mBAAmB;QACnB,kBAAkB;AAClB,QAAA,uBAAuB,aAGjB,gBAAgB,CAAA,EAAA,CAAA,CAAA;AAEjB,aAAA,CAAA,IAAA,GAAA,EAAA,CAAA,mBAAA,CAAA,EAAA,UAAA,EAAA,QAAA,EAAA,OAAA,EAAA,SAAA,EAAA,QAAA,EAAA,EAAA,EAAA,IAAA,EAAA,aAAa,EAdb,OAAA,EAAA,CAAA;YACL,YAAY;YACZ,kBAAkB;YAClB,aAAa;YACb,qBAAqB;YACrB,oBAAoB;YACpB,kBAAkB;YAClB,mBAAmB;YACnB,kBAAkB;YAClB,uBAAuB;AAC1B,SAAA,CAAA,EAAA,CAAA,CAAA;4FAIQ,aAAa,EAAA,UAAA,EAAA,CAAA;kBAfzB,QAAQ;AAAC,YAAA,IAAA,EAAA,CAAA;AACN,oBAAA,OAAO,EAAE;wBACL,YAAY;wBACZ,kBAAkB;wBAClB,aAAa;wBACb,qBAAqB;wBACrB,oBAAoB;wBACpB,kBAAkB;wBAClB,mBAAmB;wBACnB,kBAAkB;wBAClB,uBAAuB;AAC1B,qBAAA;oBACD,YAAY,EAAE,CAAC,gBAAgB,CAAC;oBAChC,OAAO,EAAE,CAAC,gBAAgB,CAAC;AAC9B,iBAAA,CAAA;;;AC7BD;;AAEG;;;;"}
|
|
@@ -11,7 +11,7 @@ import { tuiSvgLinearGradientProcessor, tuiIsString, tuiAssert, tuiGetDocumentOr
|
|
|
11
11
|
import { TUI_CACHE_BUSTING_PAYLOAD, TUI_ICON_ERROR } from '@taiga-ui/core/constants';
|
|
12
12
|
import * as i3 from '@taiga-ui/core/services';
|
|
13
13
|
import { TuiSvgService } from '@taiga-ui/core/services';
|
|
14
|
-
import { TUI_ICONS_PATH, TUI_SVG_SRC_PROCESSOR, TUI_SVG_CONTENT_PROCESSOR, TUI_SANITIZER } from '@taiga-ui/core/tokens';
|
|
14
|
+
import { TUI_DEFAULT_ICONS_PLACE, TUI_ICONS_PLACE, TUI_ICONS_PATH, TUI_SVG_SRC_PROCESSOR, TUI_SVG_CONTENT_PROCESSOR, TUI_SANITIZER } from '@taiga-ui/core/tokens';
|
|
15
15
|
import { tuiIsPresumedHTMLString } from '@taiga-ui/core/utils/miscellaneous';
|
|
16
16
|
import { identity, ReplaySubject, of } from 'rxjs';
|
|
17
17
|
import { switchMap, startWith, catchError, map } from 'rxjs/operators';
|
|
@@ -77,7 +77,8 @@ const TUI_DEPRECATED_ICONS = {
|
|
|
77
77
|
};
|
|
78
78
|
|
|
79
79
|
const TUI_SVG_DEFAULT_OPTIONS = {
|
|
80
|
-
|
|
80
|
+
iconsPlace: TUI_DEFAULT_ICONS_PLACE,
|
|
81
|
+
path: tuiIconsPathFactory(TUI_DEFAULT_ICONS_PLACE),
|
|
81
82
|
srcProcessor: identity,
|
|
82
83
|
contentProcessor: tuiSvgLinearGradientProcessor,
|
|
83
84
|
deprecated: src => {
|
|
@@ -93,6 +94,7 @@ const TUI_SVG_DEFAULT_OPTIONS = {
|
|
|
93
94
|
*/
|
|
94
95
|
const TUI_SVG_OPTIONS = new InjectionToken(`[TUI_SVG_OPTIONS]`, {
|
|
95
96
|
factory: () => ({
|
|
97
|
+
iconsPlace: inject(TUI_ICONS_PLACE),
|
|
96
98
|
path: inject(TUI_ICONS_PATH),
|
|
97
99
|
deprecated: TUI_SVG_DEFAULT_OPTIONS.deprecated,
|
|
98
100
|
srcProcessor: inject(TUI_SVG_SRC_PROCESSOR),
|
|
@@ -111,19 +113,21 @@ const tuiSvgOptionsProvider = options => ({
|
|
|
111
113
|
provide: TUI_SVG_OPTIONS,
|
|
112
114
|
deps: [
|
|
113
115
|
[new SkipSelf(), new Optional(), TUI_SVG_OPTIONS],
|
|
116
|
+
[new Optional(), TUI_ICONS_PLACE],
|
|
114
117
|
[new Optional(), TUI_ICONS_PATH],
|
|
115
118
|
[new Optional(), TUI_SVG_SRC_PROCESSOR],
|
|
116
119
|
[new Optional(), TUI_SVG_CONTENT_PROCESSOR],
|
|
117
120
|
],
|
|
118
|
-
useFactory: (fallback, path, srcProcessor, contentProcessor) => {
|
|
119
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l;
|
|
121
|
+
useFactory: (fallback, iconsPlace, path, srcProcessor, contentProcessor) => {
|
|
122
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p;
|
|
120
123
|
return ({
|
|
124
|
+
iconsPlace: (_c = (_b = (_a = options.iconsPlace) !== null && _a !== void 0 ? _a : fallback === null || fallback === void 0 ? void 0 : fallback.iconsPlace) !== null && _b !== void 0 ? _b : iconsPlace) !== null && _c !== void 0 ? _c : TUI_SVG_DEFAULT_OPTIONS.iconsPlace,
|
|
121
125
|
path: tuiIsString(options.path)
|
|
122
126
|
? tuiIconsPathFactory(options.path)
|
|
123
|
-
: (
|
|
124
|
-
deprecated: (
|
|
125
|
-
srcProcessor: (
|
|
126
|
-
contentProcessor: (
|
|
127
|
+
: (_f = (_e = (_d = options.path) !== null && _d !== void 0 ? _d : fallback === null || fallback === void 0 ? void 0 : fallback.path) !== null && _e !== void 0 ? _e : path) !== null && _f !== void 0 ? _f : TUI_SVG_DEFAULT_OPTIONS.path,
|
|
128
|
+
deprecated: (_h = (_g = options.deprecated) !== null && _g !== void 0 ? _g : fallback === null || fallback === void 0 ? void 0 : fallback.deprecated) !== null && _h !== void 0 ? _h : TUI_SVG_DEFAULT_OPTIONS.deprecated,
|
|
129
|
+
srcProcessor: (_l = (_k = (_j = options.srcProcessor) !== null && _j !== void 0 ? _j : fallback === null || fallback === void 0 ? void 0 : fallback.srcProcessor) !== null && _k !== void 0 ? _k : srcProcessor) !== null && _l !== void 0 ? _l : TUI_SVG_DEFAULT_OPTIONS.srcProcessor,
|
|
130
|
+
contentProcessor: (_p = (_o = (_m = options.contentProcessor) !== null && _m !== void 0 ? _m : fallback === null || fallback === void 0 ? void 0 : fallback.contentProcessor) !== null && _o !== void 0 ? _o : contentProcessor) !== null && _p !== void 0 ? _p : TUI_SVG_DEFAULT_OPTIONS.contentProcessor,
|
|
127
131
|
});
|
|
128
132
|
},
|
|
129
133
|
});
|
|
@@ -158,7 +162,7 @@ class TuiSvgComponent {
|
|
|
158
162
|
var _a;
|
|
159
163
|
const deprecated = this.options.deprecated(String(src));
|
|
160
164
|
ngDevMode && tuiAssert.assert(!deprecated, deprecated);
|
|
161
|
-
this.icon = ((_a = this.srcInterceptors) !== null && _a !== void 0 ? _a : []).reduce((newSrc, interceptor) => interceptor(newSrc), this.options.srcProcessor(src));
|
|
165
|
+
this.icon = ((_a = this.srcInterceptors) !== null && _a !== void 0 ? _a : []).reduce((newSrc, interceptor) => interceptor(newSrc, this.options), this.options.srcProcessor(src));
|
|
162
166
|
this.src$.next();
|
|
163
167
|
}
|
|
164
168
|
get src() {
|
|
@@ -188,7 +192,8 @@ class TuiSvgComponent {
|
|
|
188
192
|
return this.isUrl || this.isCrossDomain;
|
|
189
193
|
}
|
|
190
194
|
get isUrl() {
|
|
191
|
-
return tuiIsString(this.icon) &&
|
|
195
|
+
return (tuiIsString(this.icon) &&
|
|
196
|
+
this.icon.replace(TUI_CACHE_BUSTING_PAYLOAD, '').endsWith('.svg'));
|
|
192
197
|
}
|
|
193
198
|
get isSrc() {
|
|
194
199
|
return tuiIsString(this.icon) && tuiIsPresumedHTMLString(this.icon);
|
|
@@ -265,7 +270,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
265
270
|
}] }, { type: undefined, decorators: [{
|
|
266
271
|
type: Inject,
|
|
267
272
|
args: [TUI_SVG_OPTIONS]
|
|
268
|
-
}] }, { type:
|
|
273
|
+
}] }, { type: undefined, decorators: [{
|
|
269
274
|
type: Optional
|
|
270
275
|
}, {
|
|
271
276
|
type: Inject,
|