@taiga-ui/kit
Version:
Taiga UI Angular main components kit
83 lines • 12.4 kB
JavaScript
import { __decorate, __param } from "tslib";
import { ChangeDetectionStrategy, Component, ElementRef, HostBinding, HostListener, Inject, Input, NgZone, } from '@angular/core';
import { ANIMATION_FRAME } from '@ng-web-apis/common';
import { px, TUI_IS_ANDROID, TUI_IS_IOS, tuiDefaultProp, tuiZonefree } from '@taiga-ui/cdk';
import { MODE_PROVIDER, TUI_MODE } from '@taiga-ui/core';
import { TUI_MOBILE_AWARE } from '@taiga-ui/kit/tokens';
import { asCallable } from '@tinkoff/ng-event-plugins';
import { Observable, of, ReplaySubject } from 'rxjs';
import { debounceTime, map, mapTo, share, switchMap } from 'rxjs/operators';
let TuiUnderlineComponent = class TuiUnderlineComponent {
constructor({ nativeElement }, ngZone, animationFrame$, mobileAware, ios, android, mode$) {
this.ngZone = ngZone;
this.animationFrame$ = animationFrame$;
this.mobileAware = mobileAware;
this.ios = ios;
this.android = android;
this.mode$ = mode$;
this.isIos = this.mobileAware && this.ios;
this.isAndroid = this.mobileAware && this.android;
this.element$ = new ReplaySubject(1);
this.refresh$ = this.element$.pipe(switchMap(element => element
? this.animationFrame$.pipe(mapTo(element), tuiZonefree(this.ngZone))
: of(null)), share());
this.transition$ = asCallable(this.element$.pipe(map(element => element && 'all'), debounceTime(50)));
this.transform$ = asCallable(this.refresh$.pipe(map(element => element ? `translate3d(${px(element.offsetLeft)}, 0, 0)` : null)));
this.width$ = asCallable(this.refresh$.pipe(map(element => (element ? element.clientWidth : 0))));
nativeElement['$.style.transitionProperty'] = this.transition$;
nativeElement['$.style.transform'] = this.transform$;
nativeElement['$.style.width.px'] = this.width$;
}
set element(element) {
this.element$.next(element);
}
};
TuiUnderlineComponent.ctorParameters = () => [
{ type: ElementRef, decorators: [{ type: Inject, args: [ElementRef,] }] },
{ type: NgZone, decorators: [{ type: Inject, args: [NgZone,] }] },
{ type: Observable, decorators: [{ type: Inject, args: [ANIMATION_FRAME,] }] },
{ type: Boolean, decorators: [{ type: Inject, args: [TUI_MOBILE_AWARE,] }] },
{ type: Boolean, decorators: [{ type: Inject, args: [TUI_IS_IOS,] }] },
{ type: Boolean, decorators: [{ type: Inject, args: [TUI_IS_ANDROID,] }] },
{ type: Observable, decorators: [{ type: Inject, args: [TUI_MODE,] }] }
];
__decorate([
Input(),
tuiDefaultProp()
], TuiUnderlineComponent.prototype, "element", null);
__decorate([
HostBinding('class._ios')
], TuiUnderlineComponent.prototype, "isIos", void 0);
__decorate([
HostBinding('class._android')
], TuiUnderlineComponent.prototype, "isAndroid", void 0);
__decorate([
HostListener('$.style.transitionProperty')
], TuiUnderlineComponent.prototype, "transition$", void 0);
__decorate([
HostListener('$.style.transform')
], TuiUnderlineComponent.prototype, "transform$", void 0);
__decorate([
HostListener('$.style.width.px')
], TuiUnderlineComponent.prototype, "width$", void 0);
TuiUnderlineComponent = __decorate([
Component({
selector: 'tui-underline',
template: '',
changeDetection: ChangeDetectionStrategy.OnPush,
providers: [MODE_PROVIDER],
host: {
'($.data-mode.attr)': 'mode$',
},
styles: [":host{transition-duration:.3s;transition-timing-function:ease-in-out;position:absolute;left:0;height:100%;color:var(--tui-primary);transform:scale(0);box-shadow:inset 0 -3px 0 -1px;transition-property:none;pointer-events:none}:host._ios{border-radius:7px;background:var(--tui-base-01);box-shadow:0 3px 1px rgba(0,0,0,.04),0 3px 8px rgba(0,0,0,.12)}:host._android{box-shadow:inset 0 -3px var(--tui-link)}:host[data-mode=onDark]{color:var(--tui-text-01-night)}:host[data-mode=onLight]{color:#666}"]
}),
__param(0, Inject(ElementRef)),
__param(1, Inject(NgZone)),
__param(2, Inject(ANIMATION_FRAME)),
__param(3, Inject(TUI_MOBILE_AWARE)),
__param(4, Inject(TUI_IS_IOS)),
__param(5, Inject(TUI_IS_ANDROID)),
__param(6, Inject(TUI_MODE))
], TuiUnderlineComponent);
export { TuiUnderlineComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"underline.component.js","sourceRoot":"ng://@taiga-ui/kit/components/tabs/","sources":["underline/underline.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    NgZone,\n} from '@angular/core';\nimport {ANIMATION_FRAME} from '@ng-web-apis/common';\nimport {px, TUI_IS_ANDROID, TUI_IS_IOS, tuiDefaultProp, tuiZonefree} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER, TUI_MODE, TuiBrightness} from '@taiga-ui/core';\nimport {TUI_MOBILE_AWARE} from '@taiga-ui/kit/tokens';\nimport {asCallable} from '@tinkoff/ng-event-plugins';\nimport {Observable, of, ReplaySubject} from 'rxjs';\nimport {debounceTime, map, mapTo, share, switchMap} from 'rxjs/operators';\n\n@Component({\n    selector: 'tui-underline',\n    template: '',\n    styleUrls: ['./underline.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [MODE_PROVIDER],\n    host: {\n        '($.data-mode.attr)': 'mode$',\n    },\n})\nexport class TuiUnderlineComponent {\n    @Input()\n    @tuiDefaultProp()\n    set element(element: HTMLElement | null) {\n        this.element$.next(element);\n    }\n\n    @HostBinding('class._ios')\n    readonly isIos = this.mobileAware && this.ios;\n\n    @HostBinding('class._android')\n    readonly isAndroid = this.mobileAware && this.android;\n\n    private readonly element$ = new ReplaySubject<HTMLElement | null>(1);\n\n    private readonly refresh$ = this.element$.pipe(\n        switchMap(element =>\n            element\n                ? this.animationFrame$.pipe(mapTo(element), tuiZonefree(this.ngZone))\n                : of(null),\n        ),\n        share(),\n    );\n\n    @HostListener('$.style.transitionProperty')\n    readonly transition$ = asCallable(\n        this.element$.pipe(\n            map(element => element && 'all'),\n            debounceTime(50),\n        ),\n    );\n\n    @HostListener('$.style.transform')\n    readonly transform$ = asCallable(\n        this.refresh$.pipe(\n            map(element =>\n                element ? `translate3d(${px(element.offsetLeft)}, 0, 0)` : null,\n            ),\n        ),\n    );\n\n    @HostListener('$.style.width.px')\n    readonly width$ = asCallable(\n        this.refresh$.pipe(map(element => (element ? element.clientWidth : 0))),\n    );\n\n    constructor(\n        @Inject(ElementRef) {nativeElement}: ElementRef,\n        @Inject(NgZone) private readonly ngZone: NgZone,\n        @Inject(ANIMATION_FRAME) private readonly animationFrame$: Observable<number>,\n        @Inject(TUI_MOBILE_AWARE) private readonly mobileAware: boolean,\n        @Inject(TUI_IS_IOS) private readonly ios: boolean,\n        @Inject(TUI_IS_ANDROID) private readonly android: boolean,\n        @Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>,\n    ) {\n        nativeElement['$.style.transitionProperty'] = this.transition$;\n        nativeElement['$.style.transform'] = this.transform$;\n        nativeElement['$.style.width.px'] = this.width$;\n    }\n}\n"]}