@taiga-ui/core 3.29.2 → 3.30.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-animations.umd.js +2 -10
- package/bundles/taiga-ui-core-animations.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-alert.umd.js +10 -15
- package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-error.umd.js +2 -3
- package/bundles/taiga-ui-core-components-error.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-hints-host.umd.js +28 -7
- package/bundles/taiga-ui-core-components-hints-host.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js +1 -1
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js +34 -62
- package/bundles/taiga-ui-core-components-scroll-controls.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-dropdown.umd.js +21 -24
- package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-hint.umd.js +18 -22
- package/bundles/taiga-ui-core-directives-hint.umd.js.map +1 -1
- package/bundles/taiga-ui-core-enums.umd.js +1 -0
- package/bundles/taiga-ui-core-enums.umd.js.map +1 -1
- package/bundles/taiga-ui-core-services.umd.js +4 -3
- package/bundles/taiga-ui-core-services.umd.js.map +1 -1
- package/bundles/taiga-ui-core-tokens.umd.js +4 -1
- package/bundles/taiga-ui-core-tokens.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-format.umd.js +10 -0
- package/bundles/taiga-ui-core-utils-format.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-mask.umd.js +4 -0
- package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
- package/components/alert/alert.component.d.ts +2 -9
- package/components/error/error.component.d.ts +2 -9
- package/components/hints-host/hints-host.component.d.ts +9 -4
- package/components/scroll-controls/scroll-controls.component.d.ts +3 -11
- package/components/scroll-controls/scrollbar.directive.d.ts +3 -6
- package/constants/cache-basting-payload.d.ts +1 -1
- package/directives/dropdown/dropdown.component.d.ts +3 -11
- package/directives/dropdown/dropdown.directive.d.ts +2 -2
- package/directives/hint/hint.component.d.ts +4 -12
- package/enums/dropdown-animation.d.ts +1 -0
- package/esm2015/animations/animations.js +3 -11
- package/esm2015/components/alert/alert.component.js +12 -17
- package/esm2015/components/error/error.component.js +3 -4
- package/esm2015/components/hints-host/hints-host.component.js +27 -6
- package/esm2015/components/root/root.component.js +1 -1
- package/esm2015/components/scroll-controls/scroll-controls.component.js +6 -16
- package/esm2015/components/scroll-controls/scrollbar.directive.js +19 -39
- package/esm2015/directives/dropdown/dropdown.component.js +24 -27
- package/esm2015/directives/dropdown/dropdown.directive.js +4 -4
- package/esm2015/directives/hint/hint.component.js +19 -23
- package/esm2015/enums/dropdown-animation.js +2 -1
- package/esm2015/services/position.service.js +5 -3
- package/esm2015/tokens/animation-options.js +2 -1
- package/esm2015/tokens/scroll-ref.js +6 -3
- package/esm2015/utils/format/format-phone.js +11 -1
- package/esm2015/utils/mask/create-correction-mask.js +5 -1
- package/fesm2015/taiga-ui-core-animations.js +2 -10
- package/fesm2015/taiga-ui-core-animations.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-alert.js +11 -16
- package/fesm2015/taiga-ui-core-components-alert.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-error.js +2 -3
- package/fesm2015/taiga-ui-core-components-error.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-hints-host.js +26 -5
- package/fesm2015/taiga-ui-core-components-hints-host.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-root.js +1 -1
- package/fesm2015/taiga-ui-core-components-scroll-controls.js +23 -51
- package/fesm2015/taiga-ui-core-components-scroll-controls.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-dropdown.js +19 -22
- package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-hint.js +18 -22
- package/fesm2015/taiga-ui-core-directives-hint.js.map +1 -1
- package/fesm2015/taiga-ui-core-enums.js +1 -0
- package/fesm2015/taiga-ui-core-enums.js.map +1 -1
- package/fesm2015/taiga-ui-core-services.js +4 -2
- package/fesm2015/taiga-ui-core-services.js.map +1 -1
- package/fesm2015/taiga-ui-core-tokens.js +5 -2
- package/fesm2015/taiga-ui-core-tokens.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-format.js +10 -0
- package/fesm2015/taiga-ui-core-utils-format.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-mask.js +4 -0
- package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
- package/package.json +4 -4
- package/services/position.service.d.ts +1 -1
- package/styles/theme/wrapper/textfield.less +8 -8
- package/utils/format/format-phone.d.ts +10 -0
- package/utils/mask/create-correction-mask.d.ts +4 -0
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { ChangeDetectionStrategy, Component, Inject, NgZone, Optional, } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Inject, NgZone, } from '@angular/core';
|
|
3
2
|
import { ANIMATION_FRAME } from '@ng-web-apis/common';
|
|
4
3
|
import { tuiZoneOptimized } from '@taiga-ui/cdk';
|
|
5
4
|
import { tuiFadeIn } from '@taiga-ui/core/animations';
|
|
@@ -12,27 +11,23 @@ import * as i2 from "./scrollbar-wrapper.directive";
|
|
|
12
11
|
import * as i3 from "./scrollbar.directive";
|
|
13
12
|
import * as i4 from "rxjs";
|
|
14
13
|
export class TuiScrollControlsComponent {
|
|
15
|
-
constructor(
|
|
16
|
-
this.
|
|
14
|
+
constructor(animation, ngZone, scrollRef, animationFrame$, mode$) {
|
|
15
|
+
this.animation = animation;
|
|
17
16
|
this.ngZone = ngZone;
|
|
18
|
-
this.doc = doc;
|
|
19
17
|
this.scrollRef = scrollRef;
|
|
20
18
|
this.animationFrame$ = animationFrame$;
|
|
21
19
|
this.mode$ = mode$;
|
|
22
20
|
this.refresh$ = this.animationFrame$.pipe(throttleTime(300), map(() => this.scrollbars), startWith([false, false]), distinctUntilChanged((a, b) => a[0] === b[0] && a[1] === b[1]), tuiZoneOptimized(this.ngZone));
|
|
23
|
-
this.animation = Object.assign({ value: '' }, this.options);
|
|
24
21
|
}
|
|
25
22
|
get scrollbars() {
|
|
26
|
-
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.scrollRef
|
|
27
|
-
? this.scrollRef.nativeElement
|
|
28
|
-
: this.doc.documentElement;
|
|
23
|
+
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.scrollRef.nativeElement;
|
|
29
24
|
return [
|
|
30
25
|
Math.ceil((clientHeight / scrollHeight) * 100) < 100,
|
|
31
26
|
Math.ceil((clientWidth / scrollWidth) * 100) < 100,
|
|
32
27
|
];
|
|
33
28
|
}
|
|
34
29
|
}
|
|
35
|
-
TuiScrollControlsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollControlsComponent, deps: [{ token: TUI_ANIMATION_OPTIONS }, { token: NgZone }, { token:
|
|
30
|
+
TuiScrollControlsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollControlsComponent, deps: [{ token: TUI_ANIMATION_OPTIONS }, { token: NgZone }, { token: TUI_SCROLL_REF }, { token: ANIMATION_FRAME }, { token: TUI_MODE }], target: i0.ɵɵFactoryTarget.Component });
|
|
36
31
|
TuiScrollControlsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiScrollControlsComponent, selector: "tui-scroll-controls", host: { listeners: { "$.data-mode.attr": "mode$" } }, providers: [MODE_PROVIDER], ngImport: i0, template: "<ng-container *ngIf=\"refresh$ | async as bars\">\n <div\n *ngIf=\"bars[0]\"\n tuiScrollbarWrapper\n class=\"t-bar t-bar_vertical\"\n [@tuiFadeIn]=\"animation\"\n [class.t-bar_has-horizontal]=\"bars[1]\"\n >\n <div\n tuiScrollbar=\"vertical\"\n class=\"t-thumb\"\n ></div>\n </div>\n <div\n *ngIf=\"bars[1]\"\n tuiScrollbarWrapper\n class=\"t-bar t-bar_horizontal\"\n [@tuiFadeIn]=\"animation\"\n [class.t-bar_has-vertical]=\"bars[0]\"\n >\n <div\n tuiScrollbar=\"horizontal\"\n class=\"t-thumb\"\n ></div>\n </div>\n</ng-container>\n", styles: [":host{position:-webkit-sticky;position:sticky;top:0;left:0;z-index:1;min-width:calc(100% - 1px);min-height:calc(100% - 1px);max-width:calc(100% - 1px);max-height:calc(100% - 1px);float:left;margin-right:calc(-100% + 1px);-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:calc(-100% + 1px);margin-inline-end:calc(-100% + 1px);pointer-events:none}.t-bar{position:absolute;right:0;bottom:0;pointer-events:auto}.t-bar_vertical{top:0;width:.875rem}.t-bar_horizontal{left:0;height:.875rem}.t-bar_has-horizontal{bottom:.5rem}.t-bar_has-vertical{right:.5rem}.t-thumb{transition-property:all;transition-duration:.15s;transition-timing-function:ease-in-out;position:absolute;border-radius:6.25rem;border:.25rem solid transparent;cursor:pointer;pointer-events:auto;background:var(--tui-text-01);background-clip:content-box;box-sizing:border-box;transition-property:width,height;opacity:.2}.t-thumb:hover{opacity:.24}.t-thumb:active{opacity:.48}:host[data-mode=onDark] .t-thumb{background-color:var(--tui-text-01-night)}.t-bar_vertical .t-thumb{right:0;width:.75rem;min-height:1.25rem}.t-bar_vertical:hover .t-thumb,.t-bar_vertical .t-thumb:active{width:.875rem}.t-bar_horizontal .t-thumb{bottom:0;height:.75rem;min-width:1.25rem}.t-bar_horizontal:hover .t-thumb,.t-bar_horizontal .t-thumb:active{height:.875rem}\n"], directives: [{ type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.TuiScrollbarWrapperDirective, selector: "[tuiScrollbarWrapper]" }, { type: i3.TuiScrollbarDirective, selector: "[tuiScrollbar]", inputs: ["tuiScrollbar"] }], pipes: { "async": i1.AsyncPipe }, animations: [tuiFadeIn], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
37
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollControlsComponent, decorators: [{
|
|
38
33
|
type: Component,
|
|
@@ -53,12 +48,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
53
48
|
}] }, { type: i0.NgZone, decorators: [{
|
|
54
49
|
type: Inject,
|
|
55
50
|
args: [NgZone]
|
|
56
|
-
}] }, { type: Document, decorators: [{
|
|
57
|
-
type: Inject,
|
|
58
|
-
args: [DOCUMENT]
|
|
59
51
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
60
|
-
type: Optional
|
|
61
|
-
}, {
|
|
62
52
|
type: Inject,
|
|
63
53
|
args: [TUI_SCROLL_REF]
|
|
64
54
|
}] }, { type: i4.Observable, decorators: [{
|
|
@@ -68,4 +58,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
68
58
|
type: Inject,
|
|
69
59
|
args: [TUI_MODE]
|
|
70
60
|
}] }]; } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLWNvbnRyb2xzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zY3JvbGwtY29udHJvbHMvc2Nyb2xsLWNvbnRyb2xzLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9zY3JvbGwtY29udHJvbHMvc2Nyb2xsLWNvbnRyb2xzLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBRVQsTUFBTSxFQUNOLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDcEQsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQy9DLE9BQU8sRUFBQyxTQUFTLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNwRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFDdkQsT0FBTyxFQUFDLHFCQUFxQixFQUFFLFFBQVEsRUFBRSxjQUFjLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUd0RixPQUFPLEVBQUMsb0JBQW9CLEVBQUUsR0FBRyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQzs7Ozs7O0FBYWxGLE1BQU0sT0FBTywwQkFBMEI7SUFTbkMsWUFDNEMsU0FBMkIsRUFDbEMsTUFBYyxFQUNOLFNBQWtDLEVBQ2pDLGVBQW1DLEVBQ2xELEtBQXVDO1FBSjFCLGNBQVMsR0FBVCxTQUFTLENBQWtCO1FBQ2xDLFdBQU0sR0FBTixNQUFNLENBQVE7UUFDTixjQUFTLEdBQVQsU0FBUyxDQUF5QjtRQUNqQyxvQkFBZSxHQUFmLGVBQWUsQ0FBb0I7UUFDbEQsVUFBSyxHQUFMLEtBQUssQ0FBa0M7UUFiN0QsYUFBUSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUN6QyxZQUFZLENBQUMsR0FBRyxDQUFDLEVBQ2pCLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEVBQzFCLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxLQUFLLENBQUMsQ0FBQyxFQUN6QixvQkFBb0IsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUM5RCxnQkFBZ0IsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQ2hDLENBQUM7SUFRQyxDQUFDO0lBRUosSUFBWSxVQUFVO1FBQ2xCLE1BQU0sRUFBQyxZQUFZLEVBQUUsWUFBWSxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUMsR0FDeEQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUM7UUFFakMsT0FBTztZQUNILElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQyxZQUFZLEdBQUcsWUFBWSxDQUFDLEdBQUcsR0FBRyxDQUFDLEdBQUcsR0FBRztZQUNwRCxJQUFJLENBQUMsSUFBSSxDQUFDLENBQUMsV0FBVyxHQUFHLFdBQVcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLEdBQUc7U0FDckQsQ0FBQztJQUNOLENBQUM7O3dIQXpCUSwwQkFBMEIsa0JBVXZCLHFCQUFxQixhQUNyQixNQUFNLGFBQ04sY0FBYyxhQUNkLGVBQWUsYUFDZixRQUFROzRHQWRYLDBCQUEwQixvR0FMeEIsQ0FBQyxhQUFhLENBQUMsMEJDdkI5Qix3ckJBMEJBLHltRERKZ0IsQ0FBQyxTQUFTLENBQUM7NEZBTWQsMEJBQTBCO2tCQVh0QyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxxQkFBcUI7b0JBQy9CLFdBQVcsRUFBRSxpQ0FBaUM7b0JBQzlDLFNBQVMsRUFBRSxDQUFDLDhCQUE4QixDQUFDO29CQUMzQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsVUFBVSxFQUFFLENBQUMsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsQ0FBQyxhQUFhLENBQUM7b0JBQzFCLElBQUksRUFBRTt3QkFDRixvQkFBb0IsRUFBRSxPQUFPO3FCQUNoQztpQkFDSjs7MEJBV1EsTUFBTTsyQkFBQyxxQkFBcUI7OzBCQUM1QixNQUFNOzJCQUFDLE1BQU07OzBCQUNiLE1BQU07MkJBQUMsY0FBYzs7MEJBQ3JCLE1BQU07MkJBQUMsZUFBZTs7MEJBQ3RCLE1BQU07MkJBQUMsUUFBUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7QW5pbWF0aW9uT3B0aW9uc30gZnJvbSAnQGFuZ3VsYXIvYW5pbWF0aW9ucyc7XG5pbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBFbGVtZW50UmVmLFxuICAgIEluamVjdCxcbiAgICBOZ1pvbmUsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBTklNQVRJT05fRlJBTUV9IGZyb20gJ0BuZy13ZWItYXBpcy9jb21tb24nO1xuaW1wb3J0IHt0dWlab25lT3B0aW1pemVkfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7dHVpRmFkZUlufSBmcm9tICdAdGFpZ2EtdWkvY29yZS9hbmltYXRpb25zJztcbmltcG9ydCB7TU9ERV9QUk9WSURFUn0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvcHJvdmlkZXJzJztcbmltcG9ydCB7VFVJX0FOSU1BVElPTl9PUFRJT05TLCBUVUlfTU9ERSwgVFVJX1NDUk9MTF9SRUZ9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3Rva2Vucyc7XG5pbXBvcnQge1R1aUJyaWdodG5lc3N9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3R5cGVzJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge2Rpc3RpbmN0VW50aWxDaGFuZ2VkLCBtYXAsIHN0YXJ0V2l0aCwgdGhyb3R0bGVUaW1lfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbkBDb21wb25lbnQoe1xuICAgIHNlbGVjdG9yOiAndHVpLXNjcm9sbC1jb250cm9scycsXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Njcm9sbC1jb250cm9scy50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zY3JvbGwtY29udHJvbHMuc3R5bGUubGVzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICAgIGFuaW1hdGlvbnM6IFt0dWlGYWRlSW5dLFxuICAgIHByb3ZpZGVyczogW01PREVfUFJPVklERVJdLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgJygkLmRhdGEtbW9kZS5hdHRyKSc6ICdtb2RlJCcsXG4gICAgfSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpU2Nyb2xsQ29udHJvbHNDb21wb25lbnQge1xuICAgIHJlYWRvbmx5IHJlZnJlc2gkID0gdGhpcy5hbmltYXRpb25GcmFtZSQucGlwZShcbiAgICAgICAgdGhyb3R0bGVUaW1lKDMwMCksXG4gICAgICAgIG1hcCgoKSA9PiB0aGlzLnNjcm9sbGJhcnMpLFxuICAgICAgICBzdGFydFdpdGgoW2ZhbHNlLCBmYWxzZV0pLFxuICAgICAgICBkaXN0aW5jdFVudGlsQ2hhbmdlZCgoYSwgYikgPT4gYVswXSA9PT0gYlswXSAmJiBhWzFdID09PSBiWzFdKSxcbiAgICAgICAgdHVpWm9uZU9wdGltaXplZCh0aGlzLm5nWm9uZSksXG4gICAgKTtcblxuICAgIGNvbnN0cnVjdG9yKFxuICAgICAgICBASW5qZWN0KFRVSV9BTklNQVRJT05fT1BUSU9OUykgcmVhZG9ubHkgYW5pbWF0aW9uOiBBbmltYXRpb25PcHRpb25zLFxuICAgICAgICBASW5qZWN0KE5nWm9uZSkgcHJpdmF0ZSByZWFkb25seSBuZ1pvbmU6IE5nWm9uZSxcbiAgICAgICAgQEluamVjdChUVUlfU0NST0xMX1JFRikgcHJpdmF0ZSByZWFkb25seSBzY3JvbGxSZWY6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LFxuICAgICAgICBASW5qZWN0KEFOSU1BVElPTl9GUkFNRSkgcHJpdmF0ZSByZWFkb25seSBhbmltYXRpb25GcmFtZSQ6IE9ic2VydmFibGU8bnVtYmVyPixcbiAgICAgICAgQEluamVjdChUVUlfTU9ERSkgcmVhZG9ubHkgbW9kZSQ6IE9ic2VydmFibGU8VHVpQnJpZ2h0bmVzcyB8IG51bGw+LFxuICAgICkge31cblxuICAgIHByaXZhdGUgZ2V0IHNjcm9sbGJhcnMoKTogW2Jvb2xlYW4sIGJvb2xlYW5dIHtcbiAgICAgICAgY29uc3Qge2NsaWVudEhlaWdodCwgc2Nyb2xsSGVpZ2h0LCBjbGllbnRXaWR0aCwgc2Nyb2xsV2lkdGh9ID1cbiAgICAgICAgICAgIHRoaXMuc2Nyb2xsUmVmLm5hdGl2ZUVsZW1lbnQ7XG5cbiAgICAgICAgcmV0dXJuIFtcbiAgICAgICAgICAgIE1hdGguY2VpbCgoY2xpZW50SGVpZ2h0IC8gc2Nyb2xsSGVpZ2h0KSAqIDEwMCkgPCAxMDAsXG4gICAgICAgICAgICBNYXRoLmNlaWwoKGNsaWVudFdpZHRoIC8gc2Nyb2xsV2lkdGgpICogMTAwKSA8IDEwMCxcbiAgICAgICAgXTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwicmVmcmVzaCQgfCBhc3luYyBhcyBiYXJzXCI+XG4gICAgPGRpdlxuICAgICAgICAqbmdJZj1cImJhcnNbMF1cIlxuICAgICAgICB0dWlTY3JvbGxiYXJXcmFwcGVyXG4gICAgICAgIGNsYXNzPVwidC1iYXIgdC1iYXJfdmVydGljYWxcIlxuICAgICAgICBbQHR1aUZhZGVJbl09XCJhbmltYXRpb25cIlxuICAgICAgICBbY2xhc3MudC1iYXJfaGFzLWhvcml6b250YWxdPVwiYmFyc1sxXVwiXG4gICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgICB0dWlTY3JvbGxiYXI9XCJ2ZXJ0aWNhbFwiXG4gICAgICAgICAgICBjbGFzcz1cInQtdGh1bWJcIlxuICAgICAgICA+PC9kaXY+XG4gICAgPC9kaXY+XG4gICAgPGRpdlxuICAgICAgICAqbmdJZj1cImJhcnNbMV1cIlxuICAgICAgICB0dWlTY3JvbGxiYXJXcmFwcGVyXG4gICAgICAgIGNsYXNzPVwidC1iYXIgdC1iYXJfaG9yaXpvbnRhbFwiXG4gICAgICAgIFtAdHVpRmFkZUluXT1cImFuaW1hdGlvblwiXG4gICAgICAgIFtjbGFzcy50LWJhcl9oYXMtdmVydGljYWxdPVwiYmFyc1swXVwiXG4gICAgPlxuICAgICAgICA8ZGl2XG4gICAgICAgICAgICB0dWlTY3JvbGxiYXI9XCJob3Jpem9udGFsXCJcbiAgICAgICAgICAgIGNsYXNzPVwidC10aHVtYlwiXG4gICAgICAgID48L2Rpdj5cbiAgICA8L2Rpdj5cbjwvbmctY29udGFpbmVyPlxuIl19
|
|
@@ -1,28 +1,25 @@
|
|
|
1
|
-
import { DOCUMENT
|
|
2
|
-
import { Directive, ElementRef, Inject, Input, NgZone,
|
|
3
|
-
import { ANIMATION_FRAME
|
|
4
|
-
import { POLLING_TIME, TuiDestroyService, tuiPreventDefault, tuiStopPropagation, tuiTypedFromEvent, tuiZonefree, } from '@taiga-ui/cdk';
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { Directive, ElementRef, Inject, Input, NgZone, Renderer2, Self, } from '@angular/core';
|
|
3
|
+
import { ANIMATION_FRAME } from '@ng-web-apis/common';
|
|
4
|
+
import { POLLING_TIME, TuiDestroyService, tuiPreventDefault, tuiScrollFrom, tuiStopPropagation, tuiTypedFromEvent, tuiZonefree, } from '@taiga-ui/cdk';
|
|
5
5
|
import { TUI_ELEMENT_REF, TUI_SCROLL_REF } from '@taiga-ui/core/tokens';
|
|
6
|
-
import {
|
|
6
|
+
import { merge } from 'rxjs';
|
|
7
7
|
import { map, switchMap, takeUntil, throttleTime } from 'rxjs/operators';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "rxjs";
|
|
10
|
-
import * as i2 from "@angular/common";
|
|
11
10
|
const MIN_WIDTH = 24;
|
|
12
11
|
export class TuiScrollbarDirective {
|
|
13
|
-
constructor(ngZone, renderer, destroy$, animationFrame$, wrapper, container, doc,
|
|
12
|
+
constructor(ngZone, renderer, destroy$, animationFrame$, wrapper, container, doc, el) {
|
|
14
13
|
this.wrapper = wrapper;
|
|
15
14
|
this.container = container;
|
|
16
15
|
this.doc = doc;
|
|
17
|
-
this.win = win;
|
|
18
16
|
this.el = el;
|
|
19
|
-
this.viewportScroller = viewportScroller;
|
|
20
17
|
this.tuiScrollbar = 'vertical';
|
|
21
18
|
const { nativeElement } = this.el;
|
|
22
19
|
const mousedown$ = tuiTypedFromEvent(nativeElement, 'mousedown');
|
|
23
20
|
const mousemove$ = tuiTypedFromEvent(this.doc, 'mousemove');
|
|
24
21
|
const mouseup$ = tuiTypedFromEvent(this.doc, 'mouseup');
|
|
25
|
-
const mousedownWrapper$ = tuiTypedFromEvent(wrapper.nativeElement, 'mousedown');
|
|
22
|
+
const mousedownWrapper$ = tuiTypedFromEvent(this.wrapper.nativeElement, 'mousedown');
|
|
26
23
|
merge(mousedownWrapper$.pipe(tuiPreventDefault(), map(event => this.getScrolled(event, 0.5, 0.5))), mousedown$.pipe(tuiPreventDefault(), tuiStopPropagation(), switchMap(event => {
|
|
27
24
|
const rect = nativeElement.getBoundingClientRect();
|
|
28
25
|
const vertical = getOffsetVertical(event, rect);
|
|
@@ -31,22 +28,14 @@ export class TuiScrollbarDirective {
|
|
|
31
28
|
})))
|
|
32
29
|
.pipe(tuiZonefree(ngZone), takeUntil(destroy$))
|
|
33
30
|
.subscribe(([scrollTop, scrollLeft]) => {
|
|
34
|
-
const [x, y] = this.viewportScroller.getScrollPosition();
|
|
35
|
-
if (!this.container) {
|
|
36
|
-
this.viewportScroller.scrollToPosition([
|
|
37
|
-
this.tuiScrollbar === 'vertical' ? x : scrollLeft,
|
|
38
|
-
this.tuiScrollbar === 'vertical' ? scrollTop : y,
|
|
39
|
-
]);
|
|
40
|
-
return;
|
|
41
|
-
}
|
|
42
31
|
if (this.tuiScrollbar === 'vertical') {
|
|
43
|
-
renderer.setProperty(this.
|
|
32
|
+
renderer.setProperty(this.element, 'scrollTop', scrollTop);
|
|
44
33
|
}
|
|
45
34
|
else {
|
|
46
|
-
renderer.setProperty(this.
|
|
35
|
+
renderer.setProperty(this.element, 'scrollLeft', scrollLeft);
|
|
47
36
|
}
|
|
48
37
|
});
|
|
49
|
-
merge(
|
|
38
|
+
merge(animationFrame$.pipe(throttleTime(POLLING_TIME)), tuiScrollFrom(this.element))
|
|
50
39
|
.pipe(tuiZonefree(ngZone), takeUntil(destroy$))
|
|
51
40
|
.subscribe(() => {
|
|
52
41
|
if (this.tuiScrollbar === 'vertical') {
|
|
@@ -60,13 +49,13 @@ export class TuiScrollbarDirective {
|
|
|
60
49
|
});
|
|
61
50
|
}
|
|
62
51
|
get scrolled() {
|
|
63
|
-
const { scrollTop, scrollHeight, clientHeight, scrollLeft, scrollWidth, clientWidth, } = this.
|
|
52
|
+
const { scrollTop, scrollHeight, clientHeight, scrollLeft, scrollWidth, clientWidth, } = this.element;
|
|
64
53
|
return this.tuiScrollbar === 'vertical'
|
|
65
54
|
? scrollTop / (scrollHeight - clientHeight)
|
|
66
55
|
: scrollLeft / (scrollWidth - clientWidth);
|
|
67
56
|
}
|
|
68
57
|
get compensation() {
|
|
69
|
-
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.
|
|
58
|
+
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.element;
|
|
70
59
|
if (((clientHeight * clientHeight) / scrollHeight > MIN_WIDTH &&
|
|
71
60
|
this.tuiScrollbar === 'vertical') ||
|
|
72
61
|
((clientWidth * clientWidth) / scrollWidth > MIN_WIDTH &&
|
|
@@ -82,26 +71,25 @@ export class TuiScrollbarDirective {
|
|
|
82
71
|
return this.scrolled * (1 - compensation);
|
|
83
72
|
}
|
|
84
73
|
get view() {
|
|
85
|
-
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.
|
|
74
|
+
const { clientHeight, scrollHeight, clientWidth, scrollWidth } = this.element;
|
|
86
75
|
return this.tuiScrollbar === 'vertical'
|
|
87
76
|
? Math.ceil((clientHeight / scrollHeight) * 100) / 100
|
|
88
77
|
: Math.ceil((clientWidth / scrollWidth) * 100) / 100;
|
|
89
78
|
}
|
|
90
|
-
get
|
|
91
|
-
|
|
92
|
-
return ((_a = this.container) === null || _a === void 0 ? void 0 : _a.nativeElement) || this.doc.documentElement;
|
|
79
|
+
get element() {
|
|
80
|
+
return this.container.nativeElement;
|
|
93
81
|
}
|
|
94
82
|
getScrolled({ clientY, clientX }, offsetVertical, offsetHorizontal) {
|
|
95
83
|
const { offsetHeight, offsetWidth } = this.el.nativeElement;
|
|
96
84
|
const { top, left, width, height } = this.wrapper.nativeElement.getBoundingClientRect();
|
|
97
|
-
const maxTop = this.
|
|
98
|
-
const maxLeft = this.
|
|
85
|
+
const maxTop = this.element.scrollHeight - height;
|
|
86
|
+
const maxLeft = this.element.scrollWidth - width;
|
|
99
87
|
const scrolledTop = (clientY - top - offsetHeight * offsetVertical) / (height - offsetHeight);
|
|
100
88
|
const scrolledLeft = (clientX - left - offsetWidth * offsetHorizontal) / (width - offsetWidth);
|
|
101
89
|
return [maxTop * scrolledTop, maxLeft * scrolledLeft];
|
|
102
90
|
}
|
|
103
91
|
}
|
|
104
|
-
TuiScrollbarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollbarDirective, deps: [{ token: NgZone }, { token: Renderer2 }, { token: TuiDestroyService, self: true }, { token: ANIMATION_FRAME }, { token: TUI_ELEMENT_REF }, { token: TUI_SCROLL_REF
|
|
92
|
+
TuiScrollbarDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollbarDirective, deps: [{ token: NgZone }, { token: Renderer2 }, { token: TuiDestroyService, self: true }, { token: ANIMATION_FRAME }, { token: TUI_ELEMENT_REF }, { token: TUI_SCROLL_REF }, { token: DOCUMENT }, { token: ElementRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
105
93
|
TuiScrollbarDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiScrollbarDirective, selector: "[tuiScrollbar]", inputs: { tuiScrollbar: "tuiScrollbar" }, providers: [TuiDestroyService], ngImport: i0 });
|
|
106
94
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiScrollbarDirective, decorators: [{
|
|
107
95
|
type: Directive,
|
|
@@ -127,22 +115,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
127
115
|
type: Inject,
|
|
128
116
|
args: [TUI_ELEMENT_REF]
|
|
129
117
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
130
|
-
type: Optional
|
|
131
|
-
}, {
|
|
132
118
|
type: Inject,
|
|
133
119
|
args: [TUI_SCROLL_REF]
|
|
134
120
|
}] }, { type: Document, decorators: [{
|
|
135
121
|
type: Inject,
|
|
136
122
|
args: [DOCUMENT]
|
|
137
|
-
}] }, { type: Window, decorators: [{
|
|
138
|
-
type: Inject,
|
|
139
|
-
args: [WINDOW]
|
|
140
123
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
141
124
|
type: Inject,
|
|
142
125
|
args: [ElementRef]
|
|
143
|
-
}] }, { type: i2.ViewportScroller, decorators: [{
|
|
144
|
-
type: Inject,
|
|
145
|
-
args: [ViewportScroller]
|
|
146
126
|
}] }]; }, propDecorators: { tuiScrollbar: [{
|
|
147
127
|
type: Input
|
|
148
128
|
}] } });
|
|
@@ -152,4 +132,4 @@ function getOffsetVertical({ clientY }, { top, height }) {
|
|
|
152
132
|
function getOffsetHorizontal({ clientX }, { left, width }) {
|
|
153
133
|
return (clientX - left) / width;
|
|
154
134
|
}
|
|
155
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollbar.directive.js","sourceRoot":"","sources":["../../../../../projects/core/components/scroll-controls/scrollbar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT, ViewportScroller} from '@angular/common';\nimport {\n    Directive,\n    ElementRef,\n    Inject,\n    Input,\n    NgZone,\n    Optional,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {ANIMATION_FRAME, WINDOW} from '@ng-web-apis/common';\nimport {\n    POLLING_TIME,\n    TuiDestroyService,\n    tuiPreventDefault,\n    tuiStopPropagation,\n    tuiTypedFromEvent,\n    tuiZonefree,\n} from '@taiga-ui/cdk';\nimport {TUI_ELEMENT_REF, TUI_SCROLL_REF} from '@taiga-ui/core/tokens';\nimport {TuiOrientation} from '@taiga-ui/core/types';\nimport {fromEvent, merge, Observable} from 'rxjs';\nimport {map, switchMap, takeUntil, throttleTime} from 'rxjs/operators';\n\nconst MIN_WIDTH = 24;\n\n@Directive({\n    selector: '[tuiScrollbar]',\n    providers: [TuiDestroyService],\n})\nexport class TuiScrollbarDirective {\n    @Input()\n    tuiScrollbar: TuiOrientation = 'vertical';\n\n    constructor(\n        @Inject(NgZone) ngZone: NgZone,\n        @Inject(Renderer2) renderer: Renderer2,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<void>,\n        @Inject(ANIMATION_FRAME) animationFrame$: Observable<number>,\n        @Inject(TUI_ELEMENT_REF) private readonly wrapper: ElementRef<HTMLElement>,\n        @Optional()\n        @Inject(TUI_SCROLL_REF)\n        private readonly container: ElementRef<HTMLElement> | null,\n        @Inject(DOCUMENT) private readonly doc: Document,\n        @Inject(WINDOW) private readonly win: Window,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(ViewportScroller) private readonly viewportScroller: ViewportScroller,\n    ) {\n        const {nativeElement} = this.el;\n        const mousedown$ = tuiTypedFromEvent(nativeElement, 'mousedown');\n        const mousemove$ = tuiTypedFromEvent(this.doc, 'mousemove');\n        const mouseup$ = tuiTypedFromEvent(this.doc, 'mouseup');\n        const mousedownWrapper$ = tuiTypedFromEvent(wrapper.nativeElement, 'mousedown');\n\n        merge(\n            mousedownWrapper$.pipe(\n                tuiPreventDefault(),\n                map(event => this.getScrolled(event, 0.5, 0.5)),\n            ),\n            mousedown$.pipe(\n                tuiPreventDefault(),\n                tuiStopPropagation(),\n                switchMap(event => {\n                    const rect = nativeElement.getBoundingClientRect();\n                    const vertical = getOffsetVertical(event, rect);\n                    const horizontal = getOffsetHorizontal(event, rect);\n\n                    return mousemove$.pipe(\n                        map(event => this.getScrolled(event, vertical, horizontal)),\n                        takeUntil(mouseup$),\n                    );\n                }),\n            ),\n        )\n            .pipe(tuiZonefree(ngZone), takeUntil(destroy$))\n            .subscribe(([scrollTop, scrollLeft]) => {\n                const [x, y] = this.viewportScroller.getScrollPosition();\n\n                if (!this.container) {\n                    this.viewportScroller.scrollToPosition([\n                        this.tuiScrollbar === 'vertical' ? x : scrollLeft,\n                        this.tuiScrollbar === 'vertical' ? scrollTop : y,\n                    ]);\n\n                    return;\n                }\n\n                if (this.tuiScrollbar === 'vertical') {\n                    renderer.setProperty(\n                        this.container.nativeElement,\n                        'scrollTop',\n                        scrollTop,\n                    );\n                } else {\n                    renderer.setProperty(\n                        this.container.nativeElement,\n                        'scrollLeft',\n                        scrollLeft,\n                    );\n                }\n            });\n\n        merge(\n            fromEvent(this.container ? this.container.nativeElement : this.win, 'scroll'),\n            animationFrame$.pipe(throttleTime(POLLING_TIME)),\n        )\n            .pipe(tuiZonefree(ngZone), takeUntil(destroy$))\n            .subscribe(() => {\n                if (this.tuiScrollbar === 'vertical') {\n                    renderer.setStyle(nativeElement, 'top', `${this.thumb * 100}%`);\n                    renderer.setStyle(nativeElement, 'height', `${this.view * 100}%`);\n                } else {\n                    renderer.setStyle(nativeElement, 'left', `${this.thumb * 100}%`);\n                    renderer.setStyle(nativeElement, 'width', `${this.view * 100}%`);\n                }\n            });\n    }\n\n    private get scrolled(): number {\n        const {\n            scrollTop,\n            scrollHeight,\n            clientHeight,\n            scrollLeft,\n            scrollWidth,\n            clientWidth,\n        } = this.computedContainer;\n\n        return this.tuiScrollbar === 'vertical'\n            ? scrollTop / (scrollHeight - clientHeight)\n            : scrollLeft / (scrollWidth - clientWidth);\n    }\n\n    private get compensation(): number {\n        const {clientHeight, scrollHeight, clientWidth, scrollWidth} =\n            this.computedContainer;\n\n        if (\n            ((clientHeight * clientHeight) / scrollHeight > MIN_WIDTH &&\n                this.tuiScrollbar === 'vertical') ||\n            ((clientWidth * clientWidth) / scrollWidth > MIN_WIDTH &&\n                this.tuiScrollbar === 'horizontal')\n        ) {\n            return 0;\n        }\n\n        return this.tuiScrollbar === 'vertical'\n            ? MIN_WIDTH / clientHeight\n            : MIN_WIDTH / clientWidth;\n    }\n\n    private get thumb(): number {\n        const compensation = this.compensation || this.view;\n\n        return this.scrolled * (1 - compensation);\n    }\n\n    private get view(): number {\n        const {clientHeight, scrollHeight, clientWidth, scrollWidth} =\n            this.computedContainer;\n\n        return this.tuiScrollbar === 'vertical'\n            ? Math.ceil((clientHeight / scrollHeight) * 100) / 100\n            : Math.ceil((clientWidth / scrollWidth) * 100) / 100;\n    }\n\n    private get computedContainer(): Element {\n        return this.container?.nativeElement || this.doc.documentElement;\n    }\n\n    private getScrolled(\n        {clientY, clientX}: MouseEvent,\n        offsetVertical: number,\n        offsetHorizontal: number,\n    ): [number, number] {\n        const {offsetHeight, offsetWidth} = this.el.nativeElement;\n        const {top, left, width, height} =\n            this.wrapper.nativeElement.getBoundingClientRect();\n\n        const maxTop = this.computedContainer.scrollHeight - height;\n        const maxLeft = this.computedContainer.scrollWidth - width;\n        const scrolledTop =\n            (clientY - top - offsetHeight * offsetVertical) / (height - offsetHeight);\n        const scrolledLeft =\n            (clientX - left - offsetWidth * offsetHorizontal) / (width - offsetWidth);\n\n        return [maxTop * scrolledTop, maxLeft * scrolledLeft];\n    }\n}\n\nfunction getOffsetVertical({clientY}: MouseEvent, {top, height}: ClientRect): number {\n    return (clientY - top) / height;\n}\n\nfunction getOffsetHorizontal({clientX}: MouseEvent, {left, width}: ClientRect): number {\n    return (clientX - left) / width;\n}\n"]}
|
|
135
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollbar.directive.js","sourceRoot":"","sources":["../../../../../projects/core/components/scroll-controls/scrollbar.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {\n    Directive,\n    ElementRef,\n    Inject,\n    Input,\n    NgZone,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {ANIMATION_FRAME} from '@ng-web-apis/common';\nimport {\n    POLLING_TIME,\n    TuiDestroyService,\n    tuiPreventDefault,\n    tuiScrollFrom,\n    tuiStopPropagation,\n    tuiTypedFromEvent,\n    tuiZonefree,\n} from '@taiga-ui/cdk';\nimport {TUI_ELEMENT_REF, TUI_SCROLL_REF} from '@taiga-ui/core/tokens';\nimport {TuiOrientation} from '@taiga-ui/core/types';\nimport {merge, Observable} from 'rxjs';\nimport {map, switchMap, takeUntil, throttleTime} from 'rxjs/operators';\n\nconst MIN_WIDTH = 24;\n\n@Directive({\n    selector: '[tuiScrollbar]',\n    providers: [TuiDestroyService],\n})\nexport class TuiScrollbarDirective {\n    @Input()\n    tuiScrollbar: TuiOrientation = 'vertical';\n\n    constructor(\n        @Inject(NgZone) ngZone: NgZone,\n        @Inject(Renderer2) renderer: Renderer2,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<void>,\n        @Inject(ANIMATION_FRAME) animationFrame$: Observable<number>,\n        @Inject(TUI_ELEMENT_REF) private readonly wrapper: ElementRef<HTMLElement>,\n        @Inject(TUI_SCROLL_REF) private readonly container: ElementRef<HTMLElement>,\n        @Inject(DOCUMENT) private readonly doc: Document,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n    ) {\n        const {nativeElement} = this.el;\n        const mousedown$ = tuiTypedFromEvent(nativeElement, 'mousedown');\n        const mousemove$ = tuiTypedFromEvent(this.doc, 'mousemove');\n        const mouseup$ = tuiTypedFromEvent(this.doc, 'mouseup');\n        const mousedownWrapper$ = tuiTypedFromEvent(\n            this.wrapper.nativeElement,\n            'mousedown',\n        );\n\n        merge(\n            mousedownWrapper$.pipe(\n                tuiPreventDefault(),\n                map(event => this.getScrolled(event, 0.5, 0.5)),\n            ),\n            mousedown$.pipe(\n                tuiPreventDefault(),\n                tuiStopPropagation(),\n                switchMap(event => {\n                    const rect = nativeElement.getBoundingClientRect();\n                    const vertical = getOffsetVertical(event, rect);\n                    const horizontal = getOffsetHorizontal(event, rect);\n\n                    return mousemove$.pipe(\n                        map(event => this.getScrolled(event, vertical, horizontal)),\n                        takeUntil(mouseup$),\n                    );\n                }),\n            ),\n        )\n            .pipe(tuiZonefree(ngZone), takeUntil(destroy$))\n            .subscribe(([scrollTop, scrollLeft]) => {\n                if (this.tuiScrollbar === 'vertical') {\n                    renderer.setProperty(this.element, 'scrollTop', scrollTop);\n                } else {\n                    renderer.setProperty(this.element, 'scrollLeft', scrollLeft);\n                }\n            });\n\n        merge(\n            animationFrame$.pipe(throttleTime(POLLING_TIME)),\n            tuiScrollFrom(this.element),\n        )\n            .pipe(tuiZonefree(ngZone), takeUntil(destroy$))\n            .subscribe(() => {\n                if (this.tuiScrollbar === 'vertical') {\n                    renderer.setStyle(nativeElement, 'top', `${this.thumb * 100}%`);\n                    renderer.setStyle(nativeElement, 'height', `${this.view * 100}%`);\n                } else {\n                    renderer.setStyle(nativeElement, 'left', `${this.thumb * 100}%`);\n                    renderer.setStyle(nativeElement, 'width', `${this.view * 100}%`);\n                }\n            });\n    }\n\n    private get scrolled(): number {\n        const {\n            scrollTop,\n            scrollHeight,\n            clientHeight,\n            scrollLeft,\n            scrollWidth,\n            clientWidth,\n        } = this.element;\n\n        return this.tuiScrollbar === 'vertical'\n            ? scrollTop / (scrollHeight - clientHeight)\n            : scrollLeft / (scrollWidth - clientWidth);\n    }\n\n    private get compensation(): number {\n        const {clientHeight, scrollHeight, clientWidth, scrollWidth} = this.element;\n\n        if (\n            ((clientHeight * clientHeight) / scrollHeight > MIN_WIDTH &&\n                this.tuiScrollbar === 'vertical') ||\n            ((clientWidth * clientWidth) / scrollWidth > MIN_WIDTH &&\n                this.tuiScrollbar === 'horizontal')\n        ) {\n            return 0;\n        }\n\n        return this.tuiScrollbar === 'vertical'\n            ? MIN_WIDTH / clientHeight\n            : MIN_WIDTH / clientWidth;\n    }\n\n    private get thumb(): number {\n        const compensation = this.compensation || this.view;\n\n        return this.scrolled * (1 - compensation);\n    }\n\n    private get view(): number {\n        const {clientHeight, scrollHeight, clientWidth, scrollWidth} = this.element;\n\n        return this.tuiScrollbar === 'vertical'\n            ? Math.ceil((clientHeight / scrollHeight) * 100) / 100\n            : Math.ceil((clientWidth / scrollWidth) * 100) / 100;\n    }\n\n    private get element(): Element {\n        return this.container.nativeElement;\n    }\n\n    private getScrolled(\n        {clientY, clientX}: MouseEvent,\n        offsetVertical: number,\n        offsetHorizontal: number,\n    ): [number, number] {\n        const {offsetHeight, offsetWidth} = this.el.nativeElement;\n        const {top, left, width, height} =\n            this.wrapper.nativeElement.getBoundingClientRect();\n\n        const maxTop = this.element.scrollHeight - height;\n        const maxLeft = this.element.scrollWidth - width;\n        const scrolledTop =\n            (clientY - top - offsetHeight * offsetVertical) / (height - offsetHeight);\n        const scrolledLeft =\n            (clientX - left - offsetWidth * offsetHorizontal) / (width - offsetWidth);\n\n        return [maxTop * scrolledTop, maxLeft * scrolledLeft];\n    }\n}\n\nfunction getOffsetVertical({clientY}: MouseEvent, {top, height}: ClientRect): number {\n    return (clientY - top) / height;\n}\n\nfunction getOffsetHorizontal({clientX}: MouseEvent, {left, width}: ClientRect): number {\n    return (clientX - left) / width;\n}\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, ElementRef,
|
|
1
|
+
import { ChangeDetectionStrategy, Component, ElementRef, Inject, Optional, Self, } from '@angular/core';
|
|
2
2
|
import { WINDOW } from '@ng-web-apis/common';
|
|
3
3
|
import { AbstractTuiPortalHostComponent, TuiDestroyService, tuiGetClosestFocusable, tuiPx, } from '@taiga-ui/cdk';
|
|
4
4
|
import { tuiPositionAccessorFor, TuiRectAccessor, tuiRectAccessorFor, } from '@taiga-ui/core/abstract';
|
|
@@ -16,27 +16,26 @@ import * as i1 from "@taiga-ui/core/components/scrollbar";
|
|
|
16
16
|
import * as i2 from "@taiga-ui/cdk";
|
|
17
17
|
import * as i3 from "@taiga-ui/core/directives/mode";
|
|
18
18
|
import * as i4 from "@tinkoff/ng-polymorpheus";
|
|
19
|
-
import * as i5 from "
|
|
20
|
-
import * as i6 from "
|
|
21
|
-
import * as i7 from "
|
|
22
|
-
import * as i8 from "
|
|
23
|
-
import * as i9 from "
|
|
19
|
+
import * as i5 from "@taiga-ui/core/services";
|
|
20
|
+
import * as i6 from "rxjs";
|
|
21
|
+
import * as i7 from "./dropdown.directive";
|
|
22
|
+
import * as i8 from "@taiga-ui/core/abstract";
|
|
23
|
+
import * as i9 from "./dropdown-hover.directive";
|
|
24
24
|
/**
|
|
25
25
|
* @description:
|
|
26
26
|
* This component is used to show template in a portal
|
|
27
27
|
* using default style of white rounded box with a shadow
|
|
28
28
|
*/
|
|
29
29
|
export class TuiDropdownComponent {
|
|
30
|
-
constructor(position$, destroy$, directive, el, host, accessor, win,
|
|
30
|
+
constructor(visualViewportService, position$, destroy$, directive, animation, el, host, accessor, win, options, hoverDirective) {
|
|
31
31
|
this.directive = directive;
|
|
32
|
+
this.animation = animation;
|
|
32
33
|
this.el = el;
|
|
33
34
|
this.host = host;
|
|
34
35
|
this.accessor = accessor;
|
|
35
36
|
this.win = win;
|
|
36
|
-
this.animationOptions = animationOptions;
|
|
37
37
|
this.options = options;
|
|
38
38
|
this.hoverDirective = hoverDirective;
|
|
39
|
-
this.dropdownAnimation = Object.assign({ value: "fadeInTop" /* FadeInTop */ }, this.animationOptions);
|
|
40
39
|
position$
|
|
41
40
|
.pipe(map(point => this.directive.position === 'fixed'
|
|
42
41
|
? visualViewportService.correct(point)
|
|
@@ -108,8 +107,8 @@ export class TuiDropdownComponent {
|
|
|
108
107
|
focusable === null || focusable === void 0 ? void 0 : focusable.focus();
|
|
109
108
|
}
|
|
110
109
|
}
|
|
111
|
-
TuiDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownComponent, deps: [{ token: TuiPositionService }, { token: TuiDestroyService, self: true }, { token: TuiDropdownDirective }, { token:
|
|
112
|
-
TuiDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDropdownComponent, selector: "tui-dropdown", host: { properties: { "@tuiDropdownAnimation": "
|
|
110
|
+
TuiDropdownComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownComponent, deps: [{ token: TuiVisualViewportService }, { token: TuiPositionService }, { token: TuiDestroyService, self: true }, { token: TuiDropdownDirective }, { token: TUI_ANIMATION_OPTIONS }, { token: ElementRef }, { token: AbstractTuiPortalHostComponent }, { token: TuiRectAccessor }, { token: WINDOW }, { token: TUI_DROPDOWN_OPTIONS }, { token: TuiDropdownHoverDirective, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
111
|
+
TuiDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiDropdownComponent, selector: "tui-dropdown", host: { properties: { "@tuiDropdownAnimation": "animation" } }, providers: [
|
|
113
112
|
TuiDestroyService,
|
|
114
113
|
TuiPositionService,
|
|
115
114
|
tuiPositionAccessorFor('dropdown'),
|
|
@@ -128,49 +127,47 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
128
127
|
tuiRectAccessorFor('dropdown', TuiDropdownDirective),
|
|
129
128
|
],
|
|
130
129
|
animations: [tuiDropdownAnimation],
|
|
130
|
+
host: { '[@tuiDropdownAnimation]': 'animation' },
|
|
131
131
|
// @bad TODO: OnPush
|
|
132
132
|
// eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection
|
|
133
133
|
changeDetection: ChangeDetectionStrategy.Default,
|
|
134
134
|
}]
|
|
135
|
-
}], ctorParameters: function () { return [{ type: i5.
|
|
135
|
+
}], ctorParameters: function () { return [{ type: i5.TuiVisualViewportService, decorators: [{
|
|
136
|
+
type: Inject,
|
|
137
|
+
args: [TuiVisualViewportService]
|
|
138
|
+
}] }, { type: i6.Observable, decorators: [{
|
|
136
139
|
type: Inject,
|
|
137
140
|
args: [TuiPositionService]
|
|
138
|
-
}] }, { type:
|
|
141
|
+
}] }, { type: i6.Observable, decorators: [{
|
|
139
142
|
type: Self
|
|
140
143
|
}, {
|
|
141
144
|
type: Inject,
|
|
142
145
|
args: [TuiDestroyService]
|
|
143
|
-
}] }, { type:
|
|
146
|
+
}] }, { type: i7.TuiDropdownDirective, decorators: [{
|
|
144
147
|
type: Inject,
|
|
145
148
|
args: [TuiDropdownDirective]
|
|
149
|
+
}] }, { type: undefined, decorators: [{
|
|
150
|
+
type: Inject,
|
|
151
|
+
args: [TUI_ANIMATION_OPTIONS]
|
|
146
152
|
}] }, { type: i0.ElementRef, decorators: [{
|
|
147
153
|
type: Inject,
|
|
148
154
|
args: [ElementRef]
|
|
149
155
|
}] }, { type: i2.AbstractTuiPortalHostComponent, decorators: [{
|
|
150
156
|
type: Inject,
|
|
151
157
|
args: [AbstractTuiPortalHostComponent]
|
|
152
|
-
}] }, { type:
|
|
158
|
+
}] }, { type: i8.TuiRectAccessor, decorators: [{
|
|
153
159
|
type: Inject,
|
|
154
160
|
args: [TuiRectAccessor]
|
|
155
161
|
}] }, { type: Window, decorators: [{
|
|
156
162
|
type: Inject,
|
|
157
163
|
args: [WINDOW]
|
|
158
|
-
}] }, { type: undefined, decorators: [{
|
|
159
|
-
type: Inject,
|
|
160
|
-
args: [TUI_ANIMATION_OPTIONS]
|
|
161
164
|
}] }, { type: undefined, decorators: [{
|
|
162
165
|
type: Inject,
|
|
163
166
|
args: [TUI_DROPDOWN_OPTIONS]
|
|
164
|
-
}] }, { type:
|
|
167
|
+
}] }, { type: i9.TuiDropdownHoverDirective, decorators: [{
|
|
165
168
|
type: Optional
|
|
166
169
|
}, {
|
|
167
170
|
type: Inject,
|
|
168
171
|
args: [TuiDropdownHoverDirective]
|
|
169
|
-
}] }
|
|
170
|
-
type: Inject,
|
|
171
|
-
args: [TuiVisualViewportService]
|
|
172
|
-
}] }]; }, propDecorators: { dropdownAnimation: [{
|
|
173
|
-
type: HostBinding,
|
|
174
|
-
args: ['@tuiDropdownAnimation']
|
|
175
|
-
}] } });
|
|
176
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown.component.ts","../../../../../projects/core/directives/dropdown/dropdown.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AnimationOptions} from '@angular/animations';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    HostBinding,\n    Inject,\n    OnDestroy,\n    Optional,\n    Self,\n} from '@angular/core';\nimport {WINDOW} from '@ng-web-apis/common';\nimport {\n    AbstractTuiPortalHostComponent,\n    TuiDestroyService,\n    tuiGetClosestFocusable,\n    tuiPx,\n} from '@taiga-ui/cdk';\nimport {\n    tuiPositionAccessorFor,\n    TuiRectAccessor,\n    tuiRectAccessorFor,\n} from '@taiga-ui/core/abstract';\nimport {tuiDropdownAnimation} from '@taiga-ui/core/animations';\nimport {TuiDropdownAnimation} from '@taiga-ui/core/enums';\nimport {TuiPositionService, TuiVisualViewportService} from '@taiga-ui/core/services';\nimport {TUI_ANIMATION_OPTIONS} from '@taiga-ui/core/tokens';\nimport {TuiPoint} from '@taiga-ui/core/types';\nimport {Observable} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDropdownDirective} from './dropdown.directive';\nimport {TuiDropdownHoverDirective} from './dropdown-hover.directive';\nimport {TUI_DROPDOWN_OPTIONS, TuiDropdownOptions} from './dropdown-options.directive';\n\n/**\n * @description:\n * This component is used to show template in a portal\n * using default style of white rounded box with a shadow\n */\n@Component({\n    selector: 'tui-dropdown',\n    templateUrl: './dropdown.template.html',\n    styleUrls: ['./dropdown.style.less'],\n    providers: [\n        TuiDestroyService,\n        TuiPositionService,\n        tuiPositionAccessorFor('dropdown'),\n        tuiRectAccessorFor('dropdown', TuiDropdownDirective),\n    ],\n    animations: [tuiDropdownAnimation],\n    // @bad TODO: OnPush\n    // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n    changeDetection: ChangeDetectionStrategy.Default,\n})\nexport class TuiDropdownComponent implements OnDestroy {\n    @HostBinding('@tuiDropdownAnimation')\n    readonly dropdownAnimation = {\n        value: TuiDropdownAnimation.FadeInTop,\n        ...this.animationOptions,\n    };\n\n    constructor(\n        @Inject(TuiPositionService) position$: Observable<TuiPoint>,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<void>,\n        @Inject(TuiDropdownDirective) readonly directive: TuiDropdownDirective,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(AbstractTuiPortalHostComponent)\n        private readonly host: AbstractTuiPortalHostComponent,\n        @Inject(TuiRectAccessor) private readonly accessor: TuiRectAccessor,\n        @Inject(WINDOW) private readonly win: Window,\n        @Inject(TUI_ANIMATION_OPTIONS)\n        private readonly animationOptions: AnimationOptions,\n        @Inject(TUI_DROPDOWN_OPTIONS) private readonly options: TuiDropdownOptions,\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hoverDirective: TuiDropdownHoverDirective | null,\n        @Inject(TuiVisualViewportService) visualViewportService: TuiVisualViewportService,\n    ) {\n        position$\n            .pipe(\n                map(point =>\n                    this.directive.position === 'fixed'\n                        ? visualViewportService.correct(point)\n                        : point,\n                ),\n                takeUntil(destroy$),\n            )\n            .subscribe(([top, left]) => {\n                this.update(top, left);\n            });\n\n        this.updateWidth(this.accessor.getClientRect().width);\n    }\n\n    ngOnDestroy(): void {\n        this.onHoveredChange(false);\n    }\n\n    onHoveredChange(hovered: boolean): void {\n        if (this.hoverDirective) {\n            this.hoverDirective.toggle(hovered);\n        }\n    }\n\n    onTopFocus(): void {\n        this.moveFocusOutside(true);\n    }\n\n    onBottomFocus(): void {\n        this.moveFocusOutside(false);\n    }\n\n    private update(top: number, left: number): void {\n        const {style} = this.el.nativeElement;\n        const {right} = this.el.nativeElement.getBoundingClientRect();\n        const {maxHeight, offset} = this.options;\n        const {innerHeight} = this.win;\n        const {clientRect} = this.host;\n        const {position} = this.directive;\n        const rect = this.accessor.getClientRect();\n        const offsetX = position === 'fixed' ? 0 : -clientRect.left;\n        const offsetY = position === 'fixed' ? 0 : -clientRect.top;\n\n        top += offsetY;\n        left += offsetX;\n\n        const isIntersecting =\n            left < rect.right && right > rect.left && top < offsetY + 2 * offset;\n        const available = isIntersecting\n            ? rect.top - 2 * offset\n            : offsetY + innerHeight - top - offset;\n\n        style.position = position;\n        style.top = tuiPx(Math.max(top, offsetY + offset));\n        style.left = tuiPx(left);\n        style.maxHeight = tuiPx(Math.min(maxHeight, available));\n        style.width = '';\n        style.minWidth = '';\n\n        this.updateWidth(rect.width);\n    }\n\n    private updateWidth(width: number): void {\n        const {style} = this.el.nativeElement;\n\n        switch (this.options.limitWidth) {\n            case 'min':\n                style.minWidth = tuiPx(width);\n                break;\n            case 'fixed':\n                style.width = tuiPx(width);\n                break;\n            case 'auto':\n                break;\n        }\n    }\n\n    private moveFocusOutside(previous: boolean): void {\n        const {nativeElement} = this.directive.el;\n        const {ownerDocument} = nativeElement;\n        const root = ownerDocument ? ownerDocument.body : nativeElement;\n        let focusable = tuiGetClosestFocusable({initial: nativeElement, root, previous});\n\n        while (focusable !== null && nativeElement.contains(focusable)) {\n            focusable = tuiGetClosestFocusable({initial: focusable, root, previous});\n        }\n\n        focusable?.focus();\n    }\n}\n","<div\n    #activeZone=\"tuiActiveZone\"\n    tuiActiveZone\n    tuiOverscroll=\"all\"\n    class=\"t-wrapper\"\n    [tuiMode]=\"null\"\n    (tuiHoveredChange)=\"onHoveredChange($event)\"\n>\n    <tui-scrollbar class=\"t-scroll\">\n        <div\n            tabindex=\"0\"\n            (focus)=\"onTopFocus()\"\n        ></div>\n        <div\n            *polymorpheusOutlet=\"directive.content as text; context: {$implicit: activeZone}\"\n            class=\"t-primitive\"\n        >\n            {{ text }}\n        </div>\n        <div\n            tabindex=\"0\"\n            (focus)=\"onBottomFocus()\"\n        ></div>\n    </tui-scrollbar>\n</div>\n"]}
|
|
172
|
+
}] }]; } });
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown.component.ts","../../../../../projects/core/directives/dropdown/dropdown.template.html"],"names":[],"mappings":"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","sourcesContent":["import {AnimationOptions} from '@angular/animations';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    Inject,\n    OnDestroy,\n    Optional,\n    Self,\n} from '@angular/core';\nimport {WINDOW} from '@ng-web-apis/common';\nimport {\n    AbstractTuiPortalHostComponent,\n    TuiDestroyService,\n    tuiGetClosestFocusable,\n    tuiPx,\n} from '@taiga-ui/cdk';\nimport {\n    tuiPositionAccessorFor,\n    TuiRectAccessor,\n    tuiRectAccessorFor,\n} from '@taiga-ui/core/abstract';\nimport {tuiDropdownAnimation} from '@taiga-ui/core/animations';\nimport {TuiPositionService, TuiVisualViewportService} from '@taiga-ui/core/services';\nimport {TUI_ANIMATION_OPTIONS} from '@taiga-ui/core/tokens';\nimport {TuiPoint} from '@taiga-ui/core/types';\nimport {Observable} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiDropdownDirective} from './dropdown.directive';\nimport {TuiDropdownHoverDirective} from './dropdown-hover.directive';\nimport {TUI_DROPDOWN_OPTIONS, TuiDropdownOptions} from './dropdown-options.directive';\n\n/**\n * @description:\n * This component is used to show template in a portal\n * using default style of white rounded box with a shadow\n */\n@Component({\n    selector: 'tui-dropdown',\n    templateUrl: './dropdown.template.html',\n    styleUrls: ['./dropdown.style.less'],\n    providers: [\n        TuiDestroyService,\n        TuiPositionService,\n        tuiPositionAccessorFor('dropdown'),\n        tuiRectAccessorFor('dropdown', TuiDropdownDirective),\n    ],\n    animations: [tuiDropdownAnimation],\n    host: {'[@tuiDropdownAnimation]': 'animation'},\n    // @bad TODO: OnPush\n    // eslint-disable-next-line @angular-eslint/prefer-on-push-component-change-detection\n    changeDetection: ChangeDetectionStrategy.Default,\n})\nexport class TuiDropdownComponent implements OnDestroy {\n    constructor(\n        @Inject(TuiVisualViewportService) visualViewportService: TuiVisualViewportService,\n        @Inject(TuiPositionService) position$: Observable<TuiPoint>,\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<void>,\n        @Inject(TuiDropdownDirective) readonly directive: TuiDropdownDirective,\n        @Inject(TUI_ANIMATION_OPTIONS) readonly animation: AnimationOptions,\n        @Inject(ElementRef) private readonly el: ElementRef<HTMLElement>,\n        @Inject(AbstractTuiPortalHostComponent)\n        private readonly host: AbstractTuiPortalHostComponent,\n        @Inject(TuiRectAccessor) private readonly accessor: TuiRectAccessor,\n        @Inject(WINDOW) private readonly win: Window,\n        @Inject(TUI_DROPDOWN_OPTIONS) private readonly options: TuiDropdownOptions,\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hoverDirective: TuiDropdownHoverDirective | null,\n    ) {\n        position$\n            .pipe(\n                map(point =>\n                    this.directive.position === 'fixed'\n                        ? visualViewportService.correct(point)\n                        : point,\n                ),\n                takeUntil(destroy$),\n            )\n            .subscribe(([top, left]) => {\n                this.update(top, left);\n            });\n\n        this.updateWidth(this.accessor.getClientRect().width);\n    }\n\n    ngOnDestroy(): void {\n        this.onHoveredChange(false);\n    }\n\n    onHoveredChange(hovered: boolean): void {\n        if (this.hoverDirective) {\n            this.hoverDirective.toggle(hovered);\n        }\n    }\n\n    onTopFocus(): void {\n        this.moveFocusOutside(true);\n    }\n\n    onBottomFocus(): void {\n        this.moveFocusOutside(false);\n    }\n\n    private update(top: number, left: number): void {\n        const {style} = this.el.nativeElement;\n        const {right} = this.el.nativeElement.getBoundingClientRect();\n        const {maxHeight, offset} = this.options;\n        const {innerHeight} = this.win;\n        const {clientRect} = this.host;\n        const {position} = this.directive;\n        const rect = this.accessor.getClientRect();\n        const offsetX = position === 'fixed' ? 0 : -clientRect.left;\n        const offsetY = position === 'fixed' ? 0 : -clientRect.top;\n\n        top += offsetY;\n        left += offsetX;\n\n        const isIntersecting =\n            left < rect.right && right > rect.left && top < offsetY + 2 * offset;\n        const available = isIntersecting\n            ? rect.top - 2 * offset\n            : offsetY + innerHeight - top - offset;\n\n        style.position = position;\n        style.top = tuiPx(Math.max(top, offsetY + offset));\n        style.left = tuiPx(left);\n        style.maxHeight = tuiPx(Math.min(maxHeight, available));\n        style.width = '';\n        style.minWidth = '';\n\n        this.updateWidth(rect.width);\n    }\n\n    private updateWidth(width: number): void {\n        const {style} = this.el.nativeElement;\n\n        switch (this.options.limitWidth) {\n            case 'min':\n                style.minWidth = tuiPx(width);\n                break;\n            case 'fixed':\n                style.width = tuiPx(width);\n                break;\n            case 'auto':\n                break;\n        }\n    }\n\n    private moveFocusOutside(previous: boolean): void {\n        const {nativeElement} = this.directive.el;\n        const {ownerDocument} = nativeElement;\n        const root = ownerDocument ? ownerDocument.body : nativeElement;\n        let focusable = tuiGetClosestFocusable({initial: nativeElement, root, previous});\n\n        while (focusable !== null && nativeElement.contains(focusable)) {\n            focusable = tuiGetClosestFocusable({initial: focusable, root, previous});\n        }\n\n        focusable?.focus();\n    }\n}\n","<div\n    #activeZone=\"tuiActiveZone\"\n    tuiActiveZone\n    tuiOverscroll=\"all\"\n    class=\"t-wrapper\"\n    [tuiMode]=\"null\"\n    (tuiHoveredChange)=\"onHoveredChange($event)\"\n>\n    <tui-scrollbar class=\"t-scroll\">\n        <div\n            tabindex=\"0\"\n            (focus)=\"onTopFocus()\"\n        ></div>\n        <div\n            *polymorpheusOutlet=\"directive.content as text; context: {$implicit: activeZone}\"\n            class=\"t-primitive\"\n        >\n            {{ text }}\n        </div>\n        <div\n            tabindex=\"0\"\n            (focus)=\"onBottomFocus()\"\n        ></div>\n    </tui-scrollbar>\n</div>\n"]}
|
|
@@ -10,14 +10,14 @@ import { TUI_DROPDOWN_COMPONENT } from './dropdown.providers';
|
|
|
10
10
|
import * as i0 from "@angular/core";
|
|
11
11
|
import * as i1 from "@taiga-ui/cdk";
|
|
12
12
|
export class TuiDropdownDirective {
|
|
13
|
-
constructor(el,
|
|
13
|
+
constructor(el, dropdown, injector, dropdownService) {
|
|
14
14
|
this.el = el;
|
|
15
|
-
this.
|
|
15
|
+
this.dropdown = dropdown;
|
|
16
16
|
this.injector = injector;
|
|
17
17
|
this.dropdownService = dropdownService;
|
|
18
18
|
this.dropdownBoxRef = null;
|
|
19
19
|
this.type = 'dropdown';
|
|
20
|
-
this.component = new PolymorpheusComponent(this.
|
|
20
|
+
this.component = new PolymorpheusComponent(this.dropdown, this.injector);
|
|
21
21
|
}
|
|
22
22
|
get position() {
|
|
23
23
|
return tuiCheckFixedPosition(this.el.nativeElement) ? 'fixed' : 'absolute';
|
|
@@ -82,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
82
82
|
type: Input,
|
|
83
83
|
args: ['tuiDropdown']
|
|
84
84
|
}], position: [] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL2Ryb3Bkb3duL2Ryb3Bkb3duLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUdILFNBQVMsRUFDVCxVQUFVLEVBQ1YsTUFBTSxFQUNOLFFBQVEsRUFFUixLQUFLLEdBSVIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUdILHdCQUF3QixFQUN4QixPQUFPLEdBQ1YsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUNILGlCQUFpQixFQUNqQixZQUFZLEdBR2YsTUFBTSx5QkFBeUIsQ0FBQztBQUVqQyxPQUFPLEVBQUMscUJBQXFCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMzRCxPQUFPLEVBQUMscUJBQXFCLEVBQXNCLE1BQU0sMEJBQTBCLENBQUM7QUFFcEYsNENBQTRDO0FBQzVDLDJDQUEyQztBQUMzQyxPQUFPLEVBQUMsc0JBQXNCLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQzs7O0FBVTVELE1BQU0sT0FBTyxvQkFBb0I7SUFrQjdCLFlBQ2lDLEVBQTJCLEVBQ1AsUUFBdUIsRUFDckMsUUFBa0IsRUFFcEMsZUFBeUM7UUFKN0IsT0FBRSxHQUFGLEVBQUUsQ0FBeUI7UUFDUCxhQUFRLEdBQVIsUUFBUSxDQUFlO1FBQ3JDLGFBQVEsR0FBUixRQUFRLENBQVU7UUFFcEMsb0JBQWUsR0FBZixlQUFlLENBQTBCO1FBWDlELG1CQUFjLEdBQWlDLElBQUksQ0FBQztRQUUzQyxTQUFJLEdBQUcsVUFBVSxDQUFDO1FBRWxCLGNBQVMsR0FBRyxJQUFJLHFCQUFxQixDQUFDLElBQUksQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBUTFFLENBQUM7SUFHSixJQUFJLFFBQVE7UUFDUixPQUFPLHFCQUFxQixDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDO0lBQy9FLENBQUM7SUFFRCxrQkFBa0I7O1FBQ2QsTUFBQSxJQUFJLENBQUMsY0FBYywwQ0FBRSxpQkFBaUIsQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUN2RCxNQUFBLElBQUksQ0FBQyxjQUFjLDBDQUFFLGlCQUFpQixDQUFDLFlBQVksRUFBRSxDQUFDO0lBQzFELENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUU7WUFDZixJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1NBQ3RCO0lBQ0wsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxhQUFhO1FBQ1QsT0FBTyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDO0lBQ3pELENBQUM7SUFFRCxNQUFNLENBQUMsSUFBYTtRQUNoQixJQUFJLElBQUksSUFBSSxJQUFJLENBQUMsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUM5QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztTQUNsRTthQUFNLElBQUksQ0FBQyxJQUFJLElBQUksSUFBSSxDQUFDLGNBQWMsRUFBRTtZQUNyQyxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7WUFDakQsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUM7U0FDOUI7SUFDTCxDQUFDOztrSEF6RFEsb0JBQW9CLGtCQW1CakIsVUFBVSxhQUNWLHNCQUFzQixhQUN0QixRQUFRLGFBQ1Isd0JBQXdCO3NHQXRCM0Isb0JBQW9CLDJHQUxsQjtRQUNQLGlCQUFpQixDQUFDLG9CQUFvQixDQUFDO1FBQ3ZDLFlBQVksQ0FBQyxvQkFBb0IsQ0FBQztLQUNyQztBQTZCRDtJQURDLE9BQU87b0RBR1A7NEZBN0JRLG9CQUFvQjtrQkFSaEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUNBQWlDO29CQUMzQyxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsU0FBUyxFQUFFO3dCQUNQLGlCQUFpQixzQkFBc0I7d0JBQ3ZDLFlBQVksc0JBQXNCO3FCQUNyQztpQkFDSjs7MEJBb0JRLE1BQU07MkJBQUMsVUFBVTs7MEJBQ2pCLE1BQU07MkJBQUMsc0JBQXNCOzswQkFDN0IsTUFBTTsyQkFBQyxRQUFROzswQkFDZixNQUFNOzJCQUFDLHdCQUF3Qjs0Q0FacEMsT0FBTztzQkFETixLQUFLO3VCQUFDLGFBQWE7Z0JBa0JoQixRQUFRIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBBZnRlclZpZXdDaGVja2VkLFxuICAgIENvbXBvbmVudFJlZixcbiAgICBEaXJlY3RpdmUsXG4gICAgRWxlbWVudFJlZixcbiAgICBJbmplY3QsXG4gICAgSU5KRUNUT1IsXG4gICAgSW5qZWN0b3IsXG4gICAgSW5wdXQsXG4gICAgT25DaGFuZ2VzLFxuICAgIE9uRGVzdHJveSxcbiAgICBUeXBlLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gICAgVHVpQWN0aXZlWm9uZURpcmVjdGl2ZSxcbiAgICBUdWlDb250ZXh0V2l0aEltcGxpY2l0LFxuICAgIFR1aURyb3Bkb3duUG9ydGFsU2VydmljZSxcbiAgICB0dWlQdXJlLFxufSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7XG4gICAgdHVpQXNSZWN0QWNjZXNzb3IsXG4gICAgdHVpQXNWZWhpY2xlLFxuICAgIFR1aVJlY3RBY2Nlc3NvcixcbiAgICBUdWlWZWhpY2xlLFxufSBmcm9tICdAdGFpZ2EtdWkvY29yZS9hYnN0cmFjdCc7XG5pbXBvcnQge1R1aVBvcnRhbEl0ZW19IGZyb20gJ0B0YWlnYS11aS9jb3JlL2ludGVyZmFjZXMnO1xuaW1wb3J0IHt0dWlDaGVja0ZpeGVkUG9zaXRpb259IGZyb20gJ0B0YWlnYS11aS9jb3JlL3V0aWxzJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29tcG9uZW50LCBQb2x5bW9ycGhldXNDb250ZW50fSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuXG4vLyBUT0RPOiBmaW5kIHRoZSBiZXN0IHdheSBmb3IgcHJldmVudCBjeWNsZVxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9uby1jeWNsZVxuaW1wb3J0IHtUVUlfRFJPUERPV05fQ09NUE9ORU5UfSBmcm9tICcuL2Ryb3Bkb3duLnByb3ZpZGVycyc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3R1aURyb3Bkb3duXTpub3QobmctY29udGFpbmVyKScsXG4gICAgZXhwb3J0QXM6ICd0dWlEcm9wZG93bicsXG4gICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIHR1aUFzUmVjdEFjY2Vzc29yKFR1aURyb3Bkb3duRGlyZWN0aXZlKSxcbiAgICAgICAgdHVpQXNWZWhpY2xlKFR1aURyb3Bkb3duRGlyZWN0aXZlKSxcbiAgICBdLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlEcm9wZG93bkRpcmVjdGl2ZVxuICAgIGltcGxlbWVudHNcbiAgICAgICAgQWZ0ZXJWaWV3Q2hlY2tlZCxcbiAgICAgICAgT25EZXN0cm95LFxuICAgICAgICBPbkNoYW5nZXMsXG4gICAgICAgIFR1aVBvcnRhbEl0ZW0sXG4gICAgICAgIFR1aVJlY3RBY2Nlc3NvcixcbiAgICAgICAgVHVpVmVoaWNsZVxue1xuICAgIEBJbnB1dCgndHVpRHJvcGRvd24nKVxuICAgIGNvbnRlbnQ6IFBvbHltb3JwaGV1c0NvbnRlbnQ8VHVpQ29udGV4dFdpdGhJbXBsaWNpdDxUdWlBY3RpdmVab25lRGlyZWN0aXZlPj47XG5cbiAgICBkcm9wZG93bkJveFJlZjogQ29tcG9uZW50UmVmPHVua25vd24+IHwgbnVsbCA9IG51bGw7XG5cbiAgICByZWFkb25seSB0eXBlID0gJ2Ryb3Bkb3duJztcblxuICAgIHJlYWRvbmx5IGNvbXBvbmVudCA9IG5ldyBQb2x5bW9ycGhldXNDb21wb25lbnQodGhpcy5kcm9wZG93biwgdGhpcy5pbmplY3Rvcik7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChFbGVtZW50UmVmKSByZWFkb25seSBlbDogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgICAgIEBJbmplY3QoVFVJX0RST1BET1dOX0NPTVBPTkVOVCkgcHJpdmF0ZSByZWFkb25seSBkcm9wZG93bjogVHlwZTx1bmtub3duPixcbiAgICAgICAgQEluamVjdChJTkpFQ1RPUikgcHJpdmF0ZSByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IsXG4gICAgICAgIEBJbmplY3QoVHVpRHJvcGRvd25Qb3J0YWxTZXJ2aWNlKVxuICAgICAgICBwcml2YXRlIHJlYWRvbmx5IGRyb3Bkb3duU2VydmljZTogVHVpRHJvcGRvd25Qb3J0YWxTZXJ2aWNlLFxuICAgICkge31cblxuICAgIEB0dWlQdXJlXG4gICAgZ2V0IHBvc2l0aW9uKCk6ICdhYnNvbHV0ZScgfCAnZml4ZWQnIHtcbiAgICAgICAgcmV0dXJuIHR1aUNoZWNrRml4ZWRQb3NpdGlvbih0aGlzLmVsLm5hdGl2ZUVsZW1lbnQpID8gJ2ZpeGVkJyA6ICdhYnNvbHV0ZSc7XG4gICAgfVxuXG4gICAgbmdBZnRlclZpZXdDaGVja2VkKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmRyb3Bkb3duQm94UmVmPy5jaGFuZ2VEZXRlY3RvclJlZi5kZXRlY3RDaGFuZ2VzKCk7XG4gICAgICAgIHRoaXMuZHJvcGRvd25Cb3hSZWY/LmNoYW5nZURldGVjdG9yUmVmLm1hcmtGb3JDaGVjaygpO1xuICAgIH1cblxuICAgIG5nT25DaGFuZ2VzKCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMuY29udGVudCkge1xuICAgICAgICAgICAgdGhpcy50b2dnbGUoZmFsc2UpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHRoaXMudG9nZ2xlKGZhbHNlKTtcbiAgICB9XG5cbiAgICBnZXRDbGllbnRSZWN0KCk6IENsaWVudFJlY3Qge1xuICAgICAgICByZXR1cm4gdGhpcy5lbC5uYXRpdmVFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpO1xuICAgIH1cblxuICAgIHRvZ2dsZShzaG93OiBib29sZWFuKTogdm9pZCB7XG4gICAgICAgIGlmIChzaG93ICYmIHRoaXMuY29udGVudCAmJiAhdGhpcy5kcm9wZG93bkJveFJlZikge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93bkJveFJlZiA9IHRoaXMuZHJvcGRvd25TZXJ2aWNlLmFkZCh0aGlzLmNvbXBvbmVudCk7XG4gICAgICAgIH0gZWxzZSBpZiAoIXNob3cgJiYgdGhpcy5kcm9wZG93bkJveFJlZikge1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93blNlcnZpY2UucmVtb3ZlKHRoaXMuZHJvcGRvd25Cb3hSZWYpO1xuICAgICAgICAgICAgdGhpcy5kcm9wZG93bkJveFJlZiA9IG51bGw7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|