@taiga-ui/core 3.40.0 → 3.41.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/README.md +3 -3
- package/bundles/taiga-ui-core-components-alert.umd.js +21 -9
- package/bundles/taiga-ui-core-components-alert.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js +79 -24
- package/bundles/taiga-ui-core-components-hosted-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js +1 -1
- package/bundles/taiga-ui-core-components-root.umd.js.map +1 -1
- package/bundles/taiga-ui-core-constants.umd.js +1 -1
- package/bundles/taiga-ui-core-constants.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-dropdown.umd.js +52 -2
- package/bundles/taiga-ui-core-directives-dropdown.umd.js.map +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js +1 -1
- package/bundles/taiga-ui-core-directives-textfield-controller.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-format.umd.js +1 -1
- package/bundles/taiga-ui-core-utils-format.umd.js.map +1 -1
- package/bundles/taiga-ui-core-utils-mask.umd.js +6 -6
- package/bundles/taiga-ui-core-utils-mask.umd.js.map +1 -1
- package/components/alert/alert.component.d.ts +12 -4
- package/components/alert/alert.providers.d.ts +2 -0
- package/components/alert/index.d.ts +1 -0
- package/components/hosted-dropdown/dropdown-open-monitor.directive.d.ts +10 -0
- package/components/hosted-dropdown/hosted-dropdown.module.d.ts +8 -7
- package/components/hosted-dropdown/hosted-dropdown.token.d.ts +3 -0
- package/components/hosted-dropdown/index.d.ts +1 -0
- package/constants/cache-basting-payload.d.ts +1 -1
- package/constants/mask-caret-trap.d.ts +1 -1
- package/directives/dropdown/dropdown-open.directive.d.ts +10 -0
- package/directives/dropdown/dropdown.directive.d.ts +4 -2
- package/directives/dropdown/dropdown.module.d.ts +14 -13
- package/directives/dropdown/index.d.ts +1 -0
- package/esm2015/components/alert/alert.component.js +19 -11
- package/esm2015/components/alert/alert.providers.js +6 -0
- package/esm2015/components/alert/index.js +2 -1
- package/esm2015/components/hosted-dropdown/dropdown-open-monitor.directive.js +45 -0
- package/esm2015/components/hosted-dropdown/hosted-dropdown.component.js +16 -6
- package/esm2015/components/hosted-dropdown/hosted-dropdown.module.js +4 -1
- package/esm2015/components/hosted-dropdown/hosted-dropdown.token.js +3 -0
- package/esm2015/components/hosted-dropdown/index.js +2 -1
- package/esm2015/components/root/root.component.js +1 -1
- package/esm2015/constants/mask-caret-trap.js +2 -2
- package/esm2015/directives/dropdown/dropdown-open.directive.js +24 -0
- package/esm2015/directives/dropdown/dropdown.directive.js +24 -4
- package/esm2015/directives/dropdown/dropdown.module.js +6 -1
- package/esm2015/directives/dropdown/index.js +2 -1
- package/esm2015/directives/textfield-controller/textfield-appearance.directive.js +2 -2
- package/esm2015/mask/text-mask-config.js +1 -1
- package/esm2015/mask/text-mask-correction-handler.js +1 -1
- package/esm2015/mask/text-mask-list-handler.js +1 -1
- package/esm2015/mask/text-mask-list.js +1 -1
- package/esm2015/mask/text-mask-options.js +1 -1
- package/esm2015/mask/text-mask-pipe-handler.js +1 -1
- package/esm2015/mask/text-mask-pipe-result.js +1 -1
- package/esm2015/utils/format/format-phone.js +2 -2
- package/esm2015/utils/mask/create-auto-corrected-money-pipe.js +2 -2
- package/esm2015/utils/mask/create-correction-mask.js +2 -2
- package/esm2015/utils/mask/create-number-mask.js +2 -2
- package/esm2015/utils/mask/enable-auto-correct-decimal-symbol.js +2 -2
- package/esm2015/utils/mask/masked-money-value-is-empty.js +2 -2
- package/esm2015/utils/mask/masked-number-string-to-number.js +2 -2
- package/fesm2015/taiga-ui-core-components-alert.js +24 -13
- package/fesm2015/taiga-ui-core-components-alert.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js +65 -13
- package/fesm2015/taiga-ui-core-components-hosted-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-components-root.js +1 -1
- package/fesm2015/taiga-ui-core-components-root.js.map +1 -1
- package/fesm2015/taiga-ui-core-constants.js +1 -1
- package/fesm2015/taiga-ui-core-constants.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-dropdown.js +48 -4
- package/fesm2015/taiga-ui-core-directives-dropdown.js.map +1 -1
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js +1 -1
- package/fesm2015/taiga-ui-core-directives-textfield-controller.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-format.js +1 -1
- package/fesm2015/taiga-ui-core-utils-format.js.map +1 -1
- package/fesm2015/taiga-ui-core-utils-mask.js +6 -6
- package/fesm2015/taiga-ui-core-utils-mask.js.map +1 -1
- package/mask/text-mask-config.d.ts +1 -1
- package/mask/text-mask-correction-handler.d.ts +1 -1
- package/mask/text-mask-list-handler.d.ts +1 -1
- package/mask/text-mask-list.d.ts +1 -1
- package/mask/text-mask-options.d.ts +1 -1
- package/mask/text-mask-pipe-handler.d.ts +1 -1
- package/mask/text-mask-pipe-result.d.ts +1 -1
- package/package.json +6 -6
- package/utils/format/format-phone.d.ts +1 -1
- package/utils/mask/create-auto-corrected-money-pipe.d.ts +1 -1
- package/utils/mask/create-correction-mask.d.ts +1 -1
- package/utils/mask/create-number-mask.d.ts +1 -1
- package/utils/mask/enable-auto-correct-decimal-symbol.d.ts +1 -1
- package/utils/mask/masked-money-value-is-empty.d.ts +1 -1
- package/utils/mask/masked-number-string-to-number.d.ts +1 -1
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { inject, InjectionToken } from '@angular/core';
|
|
2
|
+
import { TUI_IS_MOBILE } from '@taiga-ui/cdk';
|
|
3
|
+
export const TUI_ALERT_POSITION = new InjectionToken(``, {
|
|
4
|
+
factory: () => (inject(TUI_IS_MOBILE) ? `1rem 1rem 0 auto` : `2rem 3rem 0 auto`),
|
|
5
|
+
});
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWxlcnQucHJvdmlkZXJzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2FsZXJ0L2FsZXJ0LnByb3ZpZGVycy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsTUFBTSxFQUFFLGNBQWMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUMsYUFBYSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTVDLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLElBQUksY0FBYyxDQUFTLEVBQUUsRUFBRTtJQUM3RCxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsYUFBYSxDQUFDLENBQUMsQ0FBQyxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQztDQUNuRixDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge2luamVjdCwgSW5qZWN0aW9uVG9rZW59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUVUlfSVNfTU9CSUxFfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcblxuZXhwb3J0IGNvbnN0IFRVSV9BTEVSVF9QT1NJVElPTiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxzdHJpbmc+KGBgLCB7XG4gICAgZmFjdG9yeTogKCkgPT4gKGluamVjdChUVUlfSVNfTU9CSUxFKSA/IGAxcmVtIDFyZW0gMCBhdXRvYCA6IGAycmVtIDNyZW0gMCBhdXRvYCksXG59KTtcbiJdfQ==
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * from './alert.component';
|
|
2
2
|
export * from './alert.directive';
|
|
3
3
|
export * from './alert.module';
|
|
4
|
+
export * from './alert.providers';
|
|
4
5
|
export * from './alert.service';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvYWxlcnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hbGVydC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydC5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydC5wcm92aWRlcnMnO1xuZXhwb3J0ICogZnJvbSAnLi9hbGVydC5zZXJ2aWNlJztcbiJdfQ==
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import { Directive, Inject, Optional, Self } from '@angular/core';
|
|
2
|
+
import { TuiDestroyService } from '@taiga-ui/cdk';
|
|
3
|
+
import { TuiDropdownDirective, TuiDropdownOpenDirective } from '@taiga-ui/core/directives';
|
|
4
|
+
import { filter, takeUntil } from 'rxjs/operators';
|
|
5
|
+
import { TUI_HOSTED_DROPDOWN_COMPONENT } from './hosted-dropdown.token';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "rxjs";
|
|
8
|
+
import * as i2 from "@taiga-ui/core/directives";
|
|
9
|
+
export class TuiDropdownOpenMonitorDirective {
|
|
10
|
+
constructor(destroy$, hosted, dropdown, open) {
|
|
11
|
+
open === null || open === void 0 ? void 0 : open.tuiDropdownOpenChange.pipe(filter(value => value && open.dropdown === dropdown && !hosted.focused), takeUntil(destroy$)).subscribe(() => {
|
|
12
|
+
var _a;
|
|
13
|
+
(_a = hosted.nativeFocusableElement) === null || _a === void 0 ? void 0 : _a.focus();
|
|
14
|
+
hosted.updateOpen(true);
|
|
15
|
+
});
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
TuiDropdownOpenMonitorDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownOpenMonitorDirective, deps: [{ token: TuiDestroyService, self: true }, { token: TUI_HOSTED_DROPDOWN_COMPONENT }, { token: TuiDropdownDirective, self: true }, { token: TuiDropdownOpenDirective, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
19
|
+
TuiDropdownOpenMonitorDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiDropdownOpenMonitorDirective, selector: "[tuiDropdownOpenMonitor]", providers: [TuiDestroyService], ngImport: i0 });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownOpenMonitorDirective, decorators: [{
|
|
21
|
+
type: Directive,
|
|
22
|
+
args: [{
|
|
23
|
+
selector: '[tuiDropdownOpenMonitor]',
|
|
24
|
+
providers: [TuiDestroyService],
|
|
25
|
+
}]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: i1.Observable, decorators: [{
|
|
27
|
+
type: Self
|
|
28
|
+
}, {
|
|
29
|
+
type: Inject,
|
|
30
|
+
args: [TuiDestroyService]
|
|
31
|
+
}] }, { type: undefined, decorators: [{
|
|
32
|
+
type: Inject,
|
|
33
|
+
args: [TUI_HOSTED_DROPDOWN_COMPONENT]
|
|
34
|
+
}] }, { type: i2.TuiDropdownDirective, decorators: [{
|
|
35
|
+
type: Self
|
|
36
|
+
}, {
|
|
37
|
+
type: Inject,
|
|
38
|
+
args: [TuiDropdownDirective]
|
|
39
|
+
}] }, { type: i2.TuiDropdownOpenDirective, decorators: [{
|
|
40
|
+
type: Optional
|
|
41
|
+
}, {
|
|
42
|
+
type: Inject,
|
|
43
|
+
args: [TuiDropdownOpenDirective]
|
|
44
|
+
}] }]; } });
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tb3Blbi1tb25pdG9yLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9ob3N0ZWQtZHJvcGRvd24vZHJvcGRvd24tb3Blbi1tb25pdG9yLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ2hFLE9BQU8sRUFBQyxpQkFBaUIsRUFBd0IsTUFBTSxlQUFlLENBQUM7QUFDdkUsT0FBTyxFQUFDLG9CQUFvQixFQUFFLHdCQUF3QixFQUFDLE1BQU0sMkJBQTJCLENBQUM7QUFFekYsT0FBTyxFQUFDLE1BQU0sRUFBRSxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUVqRCxPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSx5QkFBeUIsQ0FBQzs7OztBQU10RSxNQUFNLE9BQU8sK0JBQStCO0lBQ3hDLFlBQ3VDLFFBQTZCLEVBRWhFLE1BQW1FLEVBQzdCLFFBQThCLEVBR3BFLElBQXFDO1FBRXJDLElBQUksYUFBSixJQUFJLHVCQUFKLElBQUksQ0FBRSxxQkFBcUIsQ0FDdEIsSUFBSSxDQUNELE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsUUFBUSxLQUFLLFFBQVEsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsRUFDdkUsU0FBUyxDQUFDLFFBQVEsQ0FBQyxFQUV0QixTQUFTLENBQUMsR0FBRyxFQUFFOztZQUNaLE1BQUEsTUFBTSxDQUFDLHNCQUFzQiwwQ0FBRSxLQUFLLEVBQUUsQ0FBQztZQUN2QyxNQUFNLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDO1FBQzVCLENBQUMsQ0FBQyxDQUFDO0lBQ1gsQ0FBQzs7NkhBbkJRLCtCQUErQixrQkFFcEIsaUJBQWlCLHlCQUN6Qiw2QkFBNkIsYUFFckIsb0JBQW9CLHlCQUU1Qix3QkFBd0I7aUhBUDNCLCtCQUErQixtREFGN0IsQ0FBQyxpQkFBaUIsQ0FBQzs0RkFFckIsK0JBQStCO2tCQUozQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwwQkFBMEI7b0JBQ3BDLFNBQVMsRUFBRSxDQUFDLGlCQUFpQixDQUFDO2lCQUNqQzs7MEJBR1EsSUFBSTs7MEJBQUksTUFBTTsyQkFBQyxpQkFBaUI7OzBCQUNoQyxNQUFNOzJCQUFDLDZCQUE2Qjs7MEJBRXBDLElBQUk7OzBCQUFJLE1BQU07MkJBQUMsb0JBQW9COzswQkFDbkMsUUFBUTs7MEJBQ1IsTUFBTTsyQkFBQyx3QkFBd0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0RpcmVjdGl2ZSwgSW5qZWN0LCBPcHRpb25hbCwgU2VsZn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aURlc3Ryb3lTZXJ2aWNlLCBUdWlJbmplY3Rpb25Ub2tlblR5cGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkRpcmVjdGl2ZSwgVHVpRHJvcGRvd25PcGVuRGlyZWN0aXZlfSBmcm9tICdAdGFpZ2EtdWkvY29yZS9kaXJlY3RpdmVzJztcbmltcG9ydCB7T2JzZXJ2YWJsZX0gZnJvbSAncnhqcyc7XG5pbXBvcnQge2ZpbHRlciwgdGFrZVVudGlsfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5cbmltcG9ydCB7VFVJX0hPU1RFRF9EUk9QRE9XTl9DT01QT05FTlR9IGZyb20gJy4vaG9zdGVkLWRyb3Bkb3duLnRva2VuJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICdbdHVpRHJvcGRvd25PcGVuTW9uaXRvcl0nLFxuICAgIHByb3ZpZGVyczogW1R1aURlc3Ryb3lTZXJ2aWNlXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRHJvcGRvd25PcGVuTW9uaXRvckRpcmVjdGl2ZSB7XG4gICAgY29uc3RydWN0b3IoXG4gICAgICAgIEBTZWxmKCkgQEluamVjdChUdWlEZXN0cm95U2VydmljZSkgZGVzdHJveSQ6IE9ic2VydmFibGU8dW5rbm93bj4sXG4gICAgICAgIEBJbmplY3QoVFVJX0hPU1RFRF9EUk9QRE9XTl9DT01QT05FTlQpXG4gICAgICAgIGhvc3RlZDogVHVpSW5qZWN0aW9uVG9rZW5UeXBlPHR5cGVvZiBUVUlfSE9TVEVEX0RST1BET1dOX0NPTVBPTkVOVD4sXG4gICAgICAgIEBTZWxmKCkgQEluamVjdChUdWlEcm9wZG93bkRpcmVjdGl2ZSkgZHJvcGRvd246IFR1aURyb3Bkb3duRGlyZWN0aXZlLFxuICAgICAgICBAT3B0aW9uYWwoKVxuICAgICAgICBASW5qZWN0KFR1aURyb3Bkb3duT3BlbkRpcmVjdGl2ZSlcbiAgICAgICAgb3BlbjogVHVpRHJvcGRvd25PcGVuRGlyZWN0aXZlIHwgbnVsbCxcbiAgICApIHtcbiAgICAgICAgb3Blbj8udHVpRHJvcGRvd25PcGVuQ2hhbmdlXG4gICAgICAgICAgICAucGlwZShcbiAgICAgICAgICAgICAgICBmaWx0ZXIodmFsdWUgPT4gdmFsdWUgJiYgb3Blbi5kcm9wZG93biA9PT0gZHJvcGRvd24gJiYgIWhvc3RlZC5mb2N1c2VkKSxcbiAgICAgICAgICAgICAgICB0YWtlVW50aWwoZGVzdHJveSQpLFxuICAgICAgICAgICAgKVxuICAgICAgICAgICAgLnN1YnNjcmliZSgoKSA9PiB7XG4gICAgICAgICAgICAgICAgaG9zdGVkLm5hdGl2ZUZvY3VzYWJsZUVsZW1lbnQ/LmZvY3VzKCk7XG4gICAgICAgICAgICAgICAgaG9zdGVkLnVwZGF0ZU9wZW4odHJ1ZSk7XG4gICAgICAgICAgICB9KTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -8,13 +8,15 @@ import { shouldCall } from '@tinkoff/ng-event-plugins';
|
|
|
8
8
|
import { BehaviorSubject, EMPTY, merge } from 'rxjs';
|
|
9
9
|
import { distinctUntilChanged, skip } from 'rxjs/operators';
|
|
10
10
|
import { TuiAccessorProxyDirective } from './accessor-proxy.directive';
|
|
11
|
+
import { TUI_HOSTED_DROPDOWN_COMPONENT } from './hosted-dropdown.token';
|
|
11
12
|
import { TuiHostedDropdownConnectorDirective } from './hosted-dropdown-connector.directive';
|
|
12
13
|
import * as i0 from "@angular/core";
|
|
13
14
|
import * as i1 from "@taiga-ui/cdk";
|
|
14
15
|
import * as i2 from "./accessor-proxy.directive";
|
|
15
|
-
import * as i3 from "
|
|
16
|
-
import * as i4 from "@
|
|
17
|
-
import * as i5 from "@
|
|
16
|
+
import * as i3 from "./dropdown-open-monitor.directive";
|
|
17
|
+
import * as i4 from "@taiga-ui/core/directives/dropdown";
|
|
18
|
+
import * as i5 from "@tinkoff/ng-polymorpheus";
|
|
19
|
+
import * as i6 from "@angular/common";
|
|
18
20
|
function shouldClose(event) {
|
|
19
21
|
var _a;
|
|
20
22
|
return ('key' in event &&
|
|
@@ -174,7 +176,11 @@ TuiHostedDropdownComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0
|
|
|
174
176
|
deps: [[new Optional(), new Self(), TuiPositionAccessor]],
|
|
175
177
|
useFactory: (position) => position === null || position === void 0 ? void 0 : position[0],
|
|
176
178
|
},
|
|
177
|
-
|
|
179
|
+
{
|
|
180
|
+
provide: TUI_HOSTED_DROPDOWN_COMPONENT,
|
|
181
|
+
useExisting: TuiHostedDropdownComponent,
|
|
182
|
+
},
|
|
183
|
+
], queries: [{ propertyName: "dropdownHost", first: true, predicate: TuiHostedDropdownConnectorDirective, descendants: true, read: ElementRef }], viewQueries: [{ propertyName: "wrapper", first: true, predicate: ["wrapper"], descendants: true, read: ElementRef }, { propertyName: "dropdownDirective", first: true, predicate: TuiDropdownDirective, descendants: true }, { propertyName: "activeZone", first: true, predicate: TuiActiveZoneDirective, descendants: true }], ngImport: i0, template: "<div\n *tuiLet=\"(open$ | async) ?? openChange.value as isOpen\"\n #activeZone=\"tuiActiveZone\"\n tuiAccessorProxy\n tuiDropdownOpenMonitor\n class=\"t-wrapper\"\n [tuiDropdownSided]=\"sided\"\n [tuiDropdown]=\"dropdown\"\n [tuiDropdownManual]=\"isOpen && canOpen\"\n [tuiObscuredEnabled]=\"isOpen\"\n (tuiObscured)=\"onHostObscured($event)\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <ng-content></ng-content>\n <ng-template\n #dropdown=\"polymorpheus\"\n [polymorpheus]=\"context\"\n >\n <div\n #wrapper\n class=\"t-dropdown\"\n (keydown)=\"onKeydown($event)\"\n >\n <ng-container\n *polymorpheusOutlet=\"\n content as text;\n context: {\n $implicit: activeZone,\n close: close\n }\n \"\n >\n {{ text }}\n </ng-container>\n </div>\n <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n <div></div>\n </ng-template>\n</div>\n", styles: [":host{display:inline-flex}.t-wrapper{border-radius:inherit;height:inherit;flex:1 1 auto;width:100%}.t-dropdown{height:100%}\n"], directives: [{ type: i1.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { type: i2.TuiAccessorProxyDirective, selector: "[tuiAccessorProxy]" }, { type: i3.TuiDropdownOpenMonitorDirective, selector: "[tuiDropdownOpenMonitor]" }, { type: i4.TuiDropdownPositionSidedDirective, selector: "[tuiDropdownSided]", inputs: ["tuiDropdownSided", "tuiDropdownSidedOffset"] }, { type: i4.TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: ["tuiDropdown"], exportAs: ["tuiDropdown"] }, { type: i4.TuiDropdownDriverDirective, selector: "[tuiDropdown]" }, { type: i4.TuiDropdownManualDirective, selector: "[tuiDropdown][tuiDropdownManual]", inputs: ["tuiDropdownManual"] }, { type: i1.TuiObscuredDirective, selector: "[tuiObscured]", inputs: ["tuiObscuredEnabled"], outputs: ["tuiObscured"] }, { type: i1.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i5.PolymorpheusTemplate, selector: "ng-template[polymorpheus]", inputs: ["polymorpheus"], exportAs: ["polymorpheus"] }, { type: i5.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], pipes: { "async": i6.AsyncPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
178
184
|
__decorate([
|
|
179
185
|
shouldCall(shouldClose)
|
|
180
186
|
], TuiHostedDropdownComponent.prototype, "onKeyDownEsc", null);
|
|
@@ -192,9 +198,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
192
198
|
deps: [[new Optional(), new Self(), TuiPositionAccessor]],
|
|
193
199
|
useFactory: (position) => position === null || position === void 0 ? void 0 : position[0],
|
|
194
200
|
},
|
|
201
|
+
{
|
|
202
|
+
provide: TUI_HOSTED_DROPDOWN_COMPONENT,
|
|
203
|
+
useExisting: TuiHostedDropdownComponent,
|
|
204
|
+
},
|
|
195
205
|
],
|
|
196
206
|
}]
|
|
197
|
-
}], ctorParameters: function () { return [{ type:
|
|
207
|
+
}], ctorParameters: function () { return [{ type: i4.TuiDropdownHoverDirective, decorators: [{
|
|
198
208
|
type: Self
|
|
199
209
|
}, {
|
|
200
210
|
type: Optional
|
|
@@ -248,4 +258,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
248
258
|
type: HostListener,
|
|
249
259
|
args: ['keydown.arrowUp', ['$event', 'false']]
|
|
250
260
|
}] } });
|
|
251
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosted-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.component.ts","../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.template.html"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,UAAU,EACV,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,MAAM,EACN,KAAK,EACL,QAAQ,EACR,MAAM,EACN,IAAI,EACJ,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EACH,sBAAsB,EACtB,0BAA0B,EAG1B,sBAAsB,EACtB,YAAY,EACZ,oBAAoB,EACpB,gBAAgB,EAChB,oBAAoB,EACpB,4BAA4B,GAE/B,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,mBAAmB,EAAC,MAAM,yBAAyB,CAAC;AAC5D,OAAO,EACH,oBAAoB,EACpB,yBAAyB,GAC5B,MAAM,oCAAoC,CAAC;AAC5C,OAAO,EAAC,eAAe,EAAC,MAAM,oCAAoC,CAAC;AACnE,OAAO,EAAC,UAAU,EAAC,MAAM,2BAA2B,CAAC;AAErD,OAAO,EAAC,eAAe,EAAE,KAAK,EAAE,KAAK,EAAC,MAAM,MAAM,CAAC;AACnD,OAAO,EAAC,oBAAoB,EAAE,IAAI,EAAC,MAAM,gBAAgB,CAAC;AAE1D,OAAO,EAAC,yBAAyB,EAAC,MAAM,4BAA4B,CAAC;AACrE,OAAO,EAAC,mCAAmC,EAAC,MAAM,uCAAuC,CAAC;;;;;;;AAO1F,SAAS,WAAW,CAEhB,KAA4B;;IAE5B,OAAO,CACH,KAAK,IAAI,KAAK;QACd,KAAK,CAAC,GAAG,CAAC,WAAW,EAAE,KAAK,QAAQ;QACpC,IAAI,CAAC,OAAO;QACZ,IAAI,CAAC,IAAI;QACT,CAAC,CAAA,MAAA,IAAI,CAAC,QAAQ,0CAAE,kBAAkB,CAAA,CACrC,CAAC;AACN,CAAC;AAED,uDAAuD;AAevD,MAAM,OAAO,0BAA0B;IAoCnC,YAIqB,MAAwC,EACpB,EAAc;QADlC,WAAM,GAAN,MAAM,CAAkC;QACpB,OAAE,GAAF,EAAE,CAAY;QA/BvD,0BAA0B;QACjB,eAAU,GAAG,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QASjD,UAAK,GAAG,KAAK,CAAC;QAGd,YAAO,GAAG,IAAI,CAAC;QAGN,UAAK,GAAG,KAAK,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,IAAI,KAAK,CAAC,CAAC,IAAI,CAC9D,IAAI,CAAC,CAAC,CAAC,EACP,oBAAoB,EAAE,CACzB,CAAC;QAGO,kBAAa,GAAG,IAAI,YAAY,EAAW,CAAC;QAuH5C,UAAK,GAAG,GAAS,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IA7GjD,CAAC;IAEJ,IACI,IAAI,CAAC,IAAa;QAClB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC/B,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC;IACjC,CAAC;IAED,IAAI,IAAI;;QACJ,OAAO,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,aAAa,KAAI,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;IACrE,CAAC;IAED,IAAI,YAAY;;QACZ,OAAO,CACH,CAAA,MAAA,IAAI,CAAC,YAAY,0CAAE,aAAa;YAChC,IAAI,CAAC,sBAAsB;YAC3B,IAAI,CAAC,EAAE,CAAC,aAAa,CACxB,CAAC;IACN,CAAC;IAED,IAAI,QAAQ;;QACR,OAAO,MAAA,MAAA,IAAI,CAAC,iBAAiB,0CAAE,cAAc,0CAAE,QAAQ,CAAC,aAAa,CAAC;IAC1E,CAAC;IAED,IAAI,sBAAsB;QACtB,OAAO,4BAA4B,CAAC,IAAI,CAAC,IAAI,CAAC;YAC1C,CAAC,CAAC,IAAI,CAAC,IAAI;YACX,CAAC,CAAC,sBAAsB,CAAC;gBACnB,OAAO,EAAE,IAAI,CAAC,IAAI;gBAClB,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,aAAa;aAC9B,CAAC,CAAC;IACb,CAAC;IAED,IACI,OAAO;QACP,OAAO,CACH,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC;YAC/B,CAAC,IAAI,CAAC,IAAI;gBACN,CAAC,CAAC,IAAI,CAAC,OAAO;gBACd,oBAAoB,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC,CACxD,CAAC;IACN,CAAC;IAGD,SAAS,CAAC,MAAmB;QACzB,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;YACrC,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SAC1B;IACL,CAAC;IAGD,OAAO,CAAC,MAAmB;;QACvB,IACI,CAAC,IAAI,CAAC,YAAY;YAClB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC;YAClC,CAAC,CAAA,MAAA,IAAI,CAAC,MAAM,0CAAE,OAAO,CAAA,EACvB;YACE,IAAI,CAAC,UAAU,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/B;IACL,CAAC;IAID,YAAY,CAAC,KAAY;QACrB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,aAAa,EAAE,CAAC;IACzB,CAAC;IAID,OAAO,CAAC,KAAoB,EAAE,IAAa;QACvC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IACpC,CAAC;IAED,SAAS,CAAC,EAAC,GAAG,EAAE,MAAM,EAAE,gBAAgB,EAAgB;QACpD,IACI,CAAC,gBAAgB;YACjB,eAAe,CAAC,GAAG,CAAC;YACpB,IAAI,CAAC,YAAY;YACjB,gBAAgB,CAAC,MAAM,CAAC;YACxB,CAAC,oBAAoB,CAAC,MAAM,CAAC,EAC/B;YACE,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;IACL,CAAC;IAED,YAAY,CAAC,MAAe;QACxB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,CAAC,MAAM,EAAE;YACT,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;SAC1B;IACL,CAAC;IAED,cAAc,CAAC,QAAiB;QAC5B,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAED,UAAU,CAAC,IAAa;QACpB,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO,EAAE;YACvB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;SACpB;IACL,CAAC;IAID,IAAY,YAAY;QACpB,OAAO,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;IAEO,aAAa,CAAC,KAAoB,EAAE,KAAc;QACtD,MAAM,IAAI,GAAG,IAAI,CAAC,sBAAsB,CAAC;QAEzC,IACI,CAAC,IAAI;YACL,CAAC,gBAAgB,CAAC,IAAI,CAAC;YACvB,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,CAAC;YAC3B,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,CAAC,EAC9B;YACE,OAAO;SACV;QAED,IACI,CAAC,IAAI,CAAC,OAAO;YACb,CAAC,IAAI,CAAC,IAAI;YACV,CAAC,IAAI,CAAC,QAAQ;YACd,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,kBAAkB,CAAC,EAClE;YACE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAEtB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE;gBAC7B,KAAK,CAAC,cAAc,EAAE,CAAC;aAC1B;YAED,OAAO;SACV;QAED,MAAM,OAAO,GAAG,KAAK;YACjB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa;YAC5B,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,kBAAkB,CAAC;QACpD,MAAM,SAAS,GAAG,sBAAsB,CAAC;YACrC,OAAO;YACP,IAAI,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa;YAChC,QAAQ,EAAE,CAAC,KAAK;SACnB,CAAC,CAAC;QAEH,IAAI,CAAC,SAAS,EAAE;YACZ,OAAO;SACV;QAED,SAAS,CAAC,KAAK,EAAE,CAAC;QAClB,KAAK,CAAC,cAAc,EAAE,CAAC;IAC3B,CAAC;IAEO,aAAa;QACjB,IAAI,IAAI,CAAC,OAAO,EAAE;YACd,IAAI,CAAC,SAAS,EAAE,CAAC;SACpB;QAED,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAC3B,CAAC;IAEO,SAAS;QACb,MAAM,IAAI,GAAG,IAAI,CAAC,sBAAsB,CAAC;QAEzC,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,KAAK,CAAC,EAAC,aAAa,EAAE,IAAI,EAAC,CAAC,CAAC;SACrC;IACL,CAAC;IAEO,aAAa,CAAC,OAAgB;QAClC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACrC,CAAC;;wHA3NQ,0BAA0B,kBAuCvB,yBAAyB,yCAEzB,UAAU;4GAzCb,0BAA0B,mfATxB;QACP,0BAA0B,CAAC,0BAA0B,CAAC;QACtD;YACI,OAAO,EAAE,yBAAyB;YAClC,IAAI,EAAE,CAAC,CAAC,IAAI,QAAQ,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE,mBAAmB,CAAC,CAAC;YACzD,UAAU,EAAE,CAAC,QAAsC,EAAE,EAAE,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,CAAC,CAAC;SACxE;KACJ,oEAGa,mCAAmC,2BAAS,UAAU,4GAGvC,UAAU,iEAG5B,oBAAoB,6EAMpB,sBAAsB,gDCxFrC,gpCAsCA;ADiJI;IAFC,UAAU,CAAC,WAAW,CAAC;8DAKvB;4FA/GQ,0BAA0B;kBAdtC,SAAS;mBAAC;oBACP,QAAQ,EAAE,qBAAqB;oBAC/B,WAAW,EAAE,iCAAiC;oBAC9C,SAAS,EAAE,CAAC,8BAA8B,CAAC;oBAC3C,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACP,0BAA0B,4BAA4B;wBACtD;4BACI,OAAO,EAAE,yBAAyB;4BAClC,IAAI,EAAE,CAAC,CAAC,IAAI,QAAQ,EAAE,EAAE,IAAI,IAAI,EAAE,EAAE,mBAAmB,CAAC,CAAC;4BACzD,UAAU,EAAE,CAAC,QAAsC,EAAE,EAAE,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,CAAC,CAAC;yBACxE;qBACJ;iBACJ;;0BAsCQ,IAAI;;0BACJ,QAAQ;;0BACR,MAAM;2BAAC,yBAAyB;;0BAEhC,MAAM;2BAAC,UAAU;4CAvCL,YAAY;sBAD5B,YAAY;uBAAC,mCAAmC,EAAE,EAAC,IAAI,EAAE,UAAU,EAAC;gBAIpD,OAAO;sBADvB,SAAS;uBAAC,SAAS,EAAE,EAAC,IAAI,EAAE,UAAU,EAAC;gBAIvB,iBAAiB;sBADjC,SAAS;uBAAC,oBAAoB;gBAOtB,UAAU;sBADlB,SAAS;uBAAC,sBAAsB;gBAIjC,OAAO;sBADN,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIG,KAAK;sBADb,MAAM;uBAAC,YAAY;gBAOX,aAAa;sBADrB,MAAM;gBAcH,IAAI;sBADP,KAAK;gBAmCF,OAAO;sBADV,WAAW;uBAAC,gCAAgC;gBAW7C,SAAS;sBADR,YAAY;uBAAC,SAAS,EAAE,CAAC,eAAe,CAAC;gBAQ1C,OAAO;sBADN,YAAY;uBAAC,OAAO,EAAE,CAAC,eAAe,CAAC;gBAaxC,YAAY;sBADX,YAAY;uBAAC,yBAAyB,EAAE,CAAC,QAAQ,CAAC;gBAQnD,OAAO;sBAFN,YAAY;uBAAC,mBAAmB,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC;;sBACpD,YAAY;uBAAC,iBAAiB,EAAE,CAAC,QAAQ,EAAE,OAAO,CAAC","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {\n    TuiActiveZoneDirective,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    TuiFocusableElementAccessor,\n    tuiGetClosestFocusable,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {TuiPositionAccessor} from '@taiga-ui/core/abstract';\nimport {\n    TuiDropdownDirective,\n    TuiDropdownHoverDirective,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, EMPTY, merge} from 'rxjs';\nimport {distinctUntilChanged, skip} from 'rxjs/operators';\n\nimport {TuiAccessorProxyDirective} from './accessor-proxy.directive';\nimport {TuiHostedDropdownConnectorDirective} from './hosted-dropdown-connector.directive';\n\nexport interface TuiHostedDropdownContext\n    extends TuiContextWithImplicit<TuiActiveZoneDirective> {\n    close(): void;\n}\n\nfunction shouldClose(\n    this: TuiHostedDropdownComponent,\n    event: Event | KeyboardEvent,\n): boolean {\n    return (\n        'key' in event &&\n        event.key.toLowerCase() === 'escape' &&\n        this.canOpen &&\n        this.open &&\n        !this.dropdown?.nextElementSibling\n    );\n}\n\n/* eslint-disable @typescript-eslint/member-ordering */\n@Component({\n    selector: 'tui-hosted-dropdown',\n    templateUrl: './hosted-dropdown.template.html',\n    styleUrls: ['./hosted-dropdown.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiHostedDropdownComponent),\n        {\n            provide: TuiAccessorProxyDirective,\n            deps: [[new Optional(), new Self(), TuiPositionAccessor]],\n            useFactory: (position: TuiPositionAccessor[] | null) => position?.[0],\n        },\n    ],\n})\nexport class TuiHostedDropdownComponent implements TuiFocusableElementAccessor {\n    @ContentChild(TuiHostedDropdownConnectorDirective, {read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    @ViewChild('wrapper', {read: ElementRef})\n    private readonly wrapper?: ElementRef<HTMLDivElement>;\n\n    @ViewChild(TuiDropdownDirective)\n    private readonly dropdownDirective?: TuiDropdownDirective;\n\n    /** TODO: rename in 4.0 */\n    readonly openChange = new BehaviorSubject(false);\n\n    @ViewChild(TuiActiveZoneDirective)\n    readonly activeZone!: TuiActiveZoneDirective;\n\n    @Input()\n    content: PolymorpheusContent<TuiHostedDropdownContext>;\n\n    @Input()\n    sided = false;\n\n    @Input()\n    canOpen = true;\n\n    @Output('openChange')\n    readonly open$ = merge(this.openChange, this.hover$ || EMPTY).pipe(\n        skip(1),\n        distinctUntilChanged(),\n    );\n\n    @Output()\n    readonly focusedChange = new EventEmitter<boolean>();\n\n    readonly context!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    constructor(\n        @Self()\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hover$: TuiDropdownHoverDirective | null,\n        @Inject(ElementRef) private readonly el: ElementRef,\n    ) {}\n\n    @Input()\n    set open(open: boolean) {\n        this.openChange.next(open);\n    }\n\n    get open(): boolean {\n        return this.openChange.value;\n    }\n\n    get host(): HTMLElement {\n        return this.dropdownHost?.nativeElement || this.el.nativeElement;\n    }\n\n    get computedHost(): HTMLElement {\n        return (\n            this.dropdownHost?.nativeElement ||\n            this.nativeFocusableElement ||\n            this.el.nativeElement\n        );\n    }\n\n    get dropdown(): HTMLElement | undefined {\n        return this.dropdownDirective?.dropdownBoxRef?.location.nativeElement;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return tuiIsNativeKeyboardFocusable(this.host)\n            ? this.host\n            : tuiGetClosestFocusable({\n                  initial: this.host,\n                  root: this.el.nativeElement,\n              });\n    }\n\n    @HostBinding('class._hosted_dropdown_focused')\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocusedIn(this.host) ||\n            (this.open &&\n                !!this.wrapper &&\n                tuiIsNativeFocusedIn(this.wrapper.nativeElement))\n        );\n    }\n\n    @HostListener('focusin', ['$event.target'])\n    onFocusIn(target: HTMLElement): void {\n        if (!this.computedHost.contains(target)) {\n            this.updateOpen(false);\n        }\n    }\n\n    @HostListener('click', ['$event.target'])\n    onClick(target: HTMLElement): void {\n        if (\n            !this.hostEditable &&\n            this.computedHost.contains(target) &&\n            !this.hover$?.hovered\n        ) {\n            this.updateOpen(!this.open);\n        }\n    }\n\n    @shouldCall(shouldClose)\n    @HostListener('document:keydown.silent', ['$event'])\n    onKeyDownEsc(event: Event): void {\n        event.stopPropagation();\n        this.closeDropdown();\n    }\n\n    @HostListener('keydown.arrowDown', ['$event', 'true'])\n    @HostListener('keydown.arrowUp', ['$event', 'false'])\n    onArrow(event: KeyboardEvent, down: boolean): void {\n        this.focusDropdown(event, down);\n    }\n\n    onKeydown({key, target, defaultPrevented}: KeyboardEvent): void {\n        if (\n            !defaultPrevented &&\n            tuiIsEditingKey(key) &&\n            this.hostEditable &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.focusHost();\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (!active) {\n            this.updateOpen(false);\n        }\n    }\n\n    onHostObscured(obscured: boolean): void {\n        if (obscured) {\n            this.closeDropdown();\n        }\n    }\n\n    updateOpen(open: boolean): void {\n        if (!open || this.canOpen) {\n            this.open = open;\n        }\n    }\n\n    readonly close = (): void => this.updateOpen(false);\n\n    private get hostEditable(): boolean {\n        return tuiIsElementEditable(this.computedHost);\n    }\n\n    private focusDropdown(event: KeyboardEvent, first: boolean): void {\n        const host = this.nativeFocusableElement;\n\n        if (\n            !host ||\n            !tuiIsHTMLElement(host) ||\n            !tuiIsElement(event.target) ||\n            !host.contains(event.target)\n        ) {\n            return;\n        }\n\n        if (\n            !this.wrapper ||\n            !this.open ||\n            !this.dropdown ||\n            !tuiIsHTMLElement(this.wrapper.nativeElement.nextElementSibling)\n        ) {\n            this.updateOpen(true);\n\n            if (!tuiIsElementEditable(host)) {\n                event.preventDefault();\n            }\n\n            return;\n        }\n\n        const initial = first\n            ? this.wrapper.nativeElement\n            : this.wrapper.nativeElement.nextElementSibling;\n        const focusable = tuiGetClosestFocusable({\n            initial,\n            root: this.wrapper.nativeElement,\n            previous: !first,\n        });\n\n        if (!focusable) {\n            return;\n        }\n\n        focusable.focus();\n        event.preventDefault();\n    }\n\n    private closeDropdown(): void {\n        if (this.focused) {\n            this.focusHost();\n        }\n\n        this.updateOpen(false);\n    }\n\n    private focusHost(): void {\n        const host = this.nativeFocusableElement;\n\n        if (host) {\n            host.focus({preventScroll: true});\n        }\n    }\n\n    private updateFocused(focused: boolean): void {\n        this.focusedChange.emit(focused);\n    }\n}\n","<div\n    *tuiLet=\"(open$ | async) ?? openChange.value as isOpen\"\n    #activeZone=\"tuiActiveZone\"\n    tuiAccessorProxy\n    class=\"t-wrapper\"\n    [tuiDropdownSided]=\"sided\"\n    [tuiDropdown]=\"dropdown\"\n    [tuiDropdownManual]=\"isOpen && canOpen\"\n    [tuiObscuredEnabled]=\"isOpen\"\n    (tuiObscured)=\"onHostObscured($event)\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <ng-content></ng-content>\n    <ng-template\n        #dropdown=\"polymorpheus\"\n        [polymorpheus]=\"context\"\n    >\n        <div\n            #wrapper\n            class=\"t-dropdown\"\n            (keydown)=\"onKeydown($event)\"\n        >\n            <ng-container\n                *polymorpheusOutlet=\"\n                    content as text;\n                    context: {\n                        $implicit: activeZone,\n                        close: close\n                    }\n                \"\n            >\n                {{ text }}\n            </ng-container>\n        </div>\n        <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n        <div></div>\n    </ng-template>\n</div>\n"]}
|
|
261
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hosted-dropdown.component.js","sourceRoot":"","sources":["../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.component.ts","../../../../../projects/core/components/hosted-dropdown/hosted-dropdown.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    ContentChild,\n    ElementRef,\n    EventEmitter,\n    HostBinding,\n    HostListener,\n    Inject,\n    Input,\n    Optional,\n    Output,\n    Self,\n    ViewChild,\n} from '@angular/core';\nimport {\n    TuiActiveZoneDirective,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    TuiFocusableElementAccessor,\n    tuiGetClosestFocusable,\n    tuiIsElement,\n    tuiIsElementEditable,\n    tuiIsHTMLElement,\n    tuiIsNativeFocusedIn,\n    tuiIsNativeKeyboardFocusable,\n    TuiNativeFocusableElement,\n} from '@taiga-ui/cdk';\nimport {TuiPositionAccessor} from '@taiga-ui/core/abstract';\nimport {\n    TuiDropdownDirective,\n    TuiDropdownHoverDirective,\n} from '@taiga-ui/core/directives/dropdown';\nimport {tuiIsEditingKey} from '@taiga-ui/core/utils/miscellaneous';\nimport {shouldCall} from '@tinkoff/ng-event-plugins';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {BehaviorSubject, EMPTY, merge} from 'rxjs';\nimport {distinctUntilChanged, skip} from 'rxjs/operators';\n\nimport {TuiAccessorProxyDirective} from './accessor-proxy.directive';\nimport {TUI_HOSTED_DROPDOWN_COMPONENT} from './hosted-dropdown.token';\nimport {TuiHostedDropdownConnectorDirective} from './hosted-dropdown-connector.directive';\n\nexport interface TuiHostedDropdownContext\n    extends TuiContextWithImplicit<TuiActiveZoneDirective> {\n    close(): void;\n}\n\nfunction shouldClose(\n    this: TuiHostedDropdownComponent,\n    event: Event | KeyboardEvent,\n): boolean {\n    return (\n        'key' in event &&\n        event.key.toLowerCase() === 'escape' &&\n        this.canOpen &&\n        this.open &&\n        !this.dropdown?.nextElementSibling\n    );\n}\n\n/* eslint-disable @typescript-eslint/member-ordering */\n@Component({\n    selector: 'tui-hosted-dropdown',\n    templateUrl: './hosted-dropdown.template.html',\n    styleUrls: ['./hosted-dropdown.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiHostedDropdownComponent),\n        {\n            provide: TuiAccessorProxyDirective,\n            deps: [[new Optional(), new Self(), TuiPositionAccessor]],\n            useFactory: (position: TuiPositionAccessor[] | null) => position?.[0],\n        },\n        {\n            provide: TUI_HOSTED_DROPDOWN_COMPONENT,\n            useExisting: TuiHostedDropdownComponent,\n        },\n    ],\n})\nexport class TuiHostedDropdownComponent implements TuiFocusableElementAccessor {\n    @ContentChild(TuiHostedDropdownConnectorDirective, {read: ElementRef})\n    private readonly dropdownHost?: ElementRef<HTMLElement>;\n\n    @ViewChild('wrapper', {read: ElementRef})\n    private readonly wrapper?: ElementRef<HTMLDivElement>;\n\n    @ViewChild(TuiDropdownDirective)\n    private readonly dropdownDirective?: TuiDropdownDirective;\n\n    /** TODO: rename in 4.0 */\n    readonly openChange = new BehaviorSubject(false);\n\n    @ViewChild(TuiActiveZoneDirective)\n    readonly activeZone!: TuiActiveZoneDirective;\n\n    @Input()\n    content: PolymorpheusContent<TuiHostedDropdownContext>;\n\n    @Input()\n    sided = false;\n\n    @Input()\n    canOpen = true;\n\n    @Output('openChange')\n    readonly open$ = merge(this.openChange, this.hover$ || EMPTY).pipe(\n        skip(1),\n        distinctUntilChanged(),\n    );\n\n    @Output()\n    readonly focusedChange = new EventEmitter<boolean>();\n\n    readonly context!: TuiContextWithImplicit<TuiActiveZoneDirective>;\n\n    constructor(\n        @Self()\n        @Optional()\n        @Inject(TuiDropdownHoverDirective)\n        private readonly hover$: TuiDropdownHoverDirective | null,\n        @Inject(ElementRef) private readonly el: ElementRef,\n    ) {}\n\n    @Input()\n    set open(open: boolean) {\n        this.openChange.next(open);\n    }\n\n    get open(): boolean {\n        return this.openChange.value;\n    }\n\n    get host(): HTMLElement {\n        return this.dropdownHost?.nativeElement || this.el.nativeElement;\n    }\n\n    get computedHost(): HTMLElement {\n        return (\n            this.dropdownHost?.nativeElement ||\n            this.nativeFocusableElement ||\n            this.el.nativeElement\n        );\n    }\n\n    get dropdown(): HTMLElement | undefined {\n        return this.dropdownDirective?.dropdownBoxRef?.location.nativeElement;\n    }\n\n    get nativeFocusableElement(): TuiNativeFocusableElement | null {\n        return tuiIsNativeKeyboardFocusable(this.host)\n            ? this.host\n            : tuiGetClosestFocusable({\n                  initial: this.host,\n                  root: this.el.nativeElement,\n              });\n    }\n\n    @HostBinding('class._hosted_dropdown_focused')\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocusedIn(this.host) ||\n            (this.open &&\n                !!this.wrapper &&\n                tuiIsNativeFocusedIn(this.wrapper.nativeElement))\n        );\n    }\n\n    @HostListener('focusin', ['$event.target'])\n    onFocusIn(target: HTMLElement): void {\n        if (!this.computedHost.contains(target)) {\n            this.updateOpen(false);\n        }\n    }\n\n    @HostListener('click', ['$event.target'])\n    onClick(target: HTMLElement): void {\n        if (\n            !this.hostEditable &&\n            this.computedHost.contains(target) &&\n            !this.hover$?.hovered\n        ) {\n            this.updateOpen(!this.open);\n        }\n    }\n\n    @shouldCall(shouldClose)\n    @HostListener('document:keydown.silent', ['$event'])\n    onKeyDownEsc(event: Event): void {\n        event.stopPropagation();\n        this.closeDropdown();\n    }\n\n    @HostListener('keydown.arrowDown', ['$event', 'true'])\n    @HostListener('keydown.arrowUp', ['$event', 'false'])\n    onArrow(event: KeyboardEvent, down: boolean): void {\n        this.focusDropdown(event, down);\n    }\n\n    onKeydown({key, target, defaultPrevented}: KeyboardEvent): void {\n        if (\n            !defaultPrevented &&\n            tuiIsEditingKey(key) &&\n            this.hostEditable &&\n            tuiIsHTMLElement(target) &&\n            !tuiIsElementEditable(target)\n        ) {\n            this.focusHost();\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n\n        if (!active) {\n            this.updateOpen(false);\n        }\n    }\n\n    onHostObscured(obscured: boolean): void {\n        if (obscured) {\n            this.closeDropdown();\n        }\n    }\n\n    updateOpen(open: boolean): void {\n        if (!open || this.canOpen) {\n            this.open = open;\n        }\n    }\n\n    readonly close = (): void => this.updateOpen(false);\n\n    private get hostEditable(): boolean {\n        return tuiIsElementEditable(this.computedHost);\n    }\n\n    private focusDropdown(event: KeyboardEvent, first: boolean): void {\n        const host = this.nativeFocusableElement;\n\n        if (\n            !host ||\n            !tuiIsHTMLElement(host) ||\n            !tuiIsElement(event.target) ||\n            !host.contains(event.target)\n        ) {\n            return;\n        }\n\n        if (\n            !this.wrapper ||\n            !this.open ||\n            !this.dropdown ||\n            !tuiIsHTMLElement(this.wrapper.nativeElement.nextElementSibling)\n        ) {\n            this.updateOpen(true);\n\n            if (!tuiIsElementEditable(host)) {\n                event.preventDefault();\n            }\n\n            return;\n        }\n\n        const initial = first\n            ? this.wrapper.nativeElement\n            : this.wrapper.nativeElement.nextElementSibling;\n        const focusable = tuiGetClosestFocusable({\n            initial,\n            root: this.wrapper.nativeElement,\n            previous: !first,\n        });\n\n        if (!focusable) {\n            return;\n        }\n\n        focusable.focus();\n        event.preventDefault();\n    }\n\n    private closeDropdown(): void {\n        if (this.focused) {\n            this.focusHost();\n        }\n\n        this.updateOpen(false);\n    }\n\n    private focusHost(): void {\n        const host = this.nativeFocusableElement;\n\n        if (host) {\n            host.focus({preventScroll: true});\n        }\n    }\n\n    private updateFocused(focused: boolean): void {\n        this.focusedChange.emit(focused);\n    }\n}\n","<div\n    *tuiLet=\"(open$ | async) ?? openChange.value as isOpen\"\n    #activeZone=\"tuiActiveZone\"\n    tuiAccessorProxy\n    tuiDropdownOpenMonitor\n    class=\"t-wrapper\"\n    [tuiDropdownSided]=\"sided\"\n    [tuiDropdown]=\"dropdown\"\n    [tuiDropdownManual]=\"isOpen && canOpen\"\n    [tuiObscuredEnabled]=\"isOpen\"\n    (tuiObscured)=\"onHostObscured($event)\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <ng-content></ng-content>\n    <ng-template\n        #dropdown=\"polymorpheus\"\n        [polymorpheus]=\"context\"\n    >\n        <div\n            #wrapper\n            class=\"t-dropdown\"\n            (keydown)=\"onKeydown($event)\"\n        >\n            <ng-container\n                *polymorpheusOutlet=\"\n                    content as text;\n                    context: {\n                        $implicit: activeZone,\n                        close: close\n                    }\n                \"\n            >\n                {{ text }}\n            </ng-container>\n        </div>\n        <!--This DIV is here to start backwards TreeWalker for focusing last focusable item on ArrowUp-->\n        <div></div>\n    </ng-template>\n</div>\n"]}
|
|
@@ -4,6 +4,7 @@ import { TuiActiveZoneModule, TuiLetModule, TuiObscuredModule } from '@taiga-ui/
|
|
|
4
4
|
import { TuiDropdownModule, TuiDropdownOptionsDirective, } from '@taiga-ui/core/directives/dropdown';
|
|
5
5
|
import { PolymorpheusModule } from '@tinkoff/ng-polymorpheus';
|
|
6
6
|
import { TuiAccessorProxyDirective } from './accessor-proxy.directive';
|
|
7
|
+
import { TuiDropdownOpenMonitorDirective } from './dropdown-open-monitor.directive';
|
|
7
8
|
import { TuiHostedDropdownComponent } from './hosted-dropdown.component';
|
|
8
9
|
import { TuiHostedDropdownConnectorDirective } from './hosted-dropdown-connector.directive';
|
|
9
10
|
import * as i0 from "@angular/core";
|
|
@@ -11,6 +12,7 @@ export class TuiHostedDropdownModule {
|
|
|
11
12
|
}
|
|
12
13
|
TuiHostedDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiHostedDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
13
14
|
TuiHostedDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiHostedDropdownModule, declarations: [TuiAccessorProxyDirective,
|
|
15
|
+
TuiDropdownOpenMonitorDirective,
|
|
14
16
|
TuiHostedDropdownComponent,
|
|
15
17
|
TuiHostedDropdownConnectorDirective], imports: [CommonModule,
|
|
16
18
|
PolymorpheusModule,
|
|
@@ -41,6 +43,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
41
43
|
],
|
|
42
44
|
declarations: [
|
|
43
45
|
TuiAccessorProxyDirective,
|
|
46
|
+
TuiDropdownOpenMonitorDirective,
|
|
44
47
|
TuiHostedDropdownComponent,
|
|
45
48
|
TuiHostedDropdownConnectorDirective,
|
|
46
49
|
],
|
|
@@ -51,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
51
54
|
],
|
|
52
55
|
}]
|
|
53
56
|
}] });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9zdGVkLWRyb3Bkb3duLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvY29tcG9uZW50cy9ob3N0ZWQtZHJvcGRvd24vaG9zdGVkLWRyb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsWUFBWSxFQUFDLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFDLFFBQVEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2QyxPQUFPLEVBQUMsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLGlCQUFpQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ25GLE9BQU8sRUFDSCxpQkFBaUIsRUFDakIsMkJBQTJCLEdBQzlCLE1BQU0sb0NBQW9DLENBQUM7QUFDNUMsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sMEJBQTBCLENBQUM7QUFFNUQsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sNEJBQTRCLENBQUM7QUFDckUsT0FBTyxFQUFDLCtCQUErQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFDbEYsT0FBTyxFQUFDLDBCQUEwQixFQUFDLE1BQU0sNkJBQTZCLENBQUM7QUFDdkUsT0FBTyxFQUFDLG1DQUFtQyxFQUFDLE1BQU0sdUNBQXVDLENBQUM7O0FBdUIxRixNQUFNLE9BQU8sdUJBQXVCOztxSEFBdkIsdUJBQXVCO3NIQUF2Qix1QkFBdUIsaUJBWDVCLHlCQUF5QjtRQUN6QiwrQkFBK0I7UUFDL0IsMEJBQTBCO1FBQzFCLG1DQUFtQyxhQVhuQyxZQUFZO1FBQ1osa0JBQWtCO1FBQ2xCLFlBQVk7UUFDWixpQkFBaUI7UUFDakIsbUJBQW1CO1FBQ25CLGlCQUFpQixhQVNqQiwwQkFBMEI7UUFDMUIsbUNBQW1DO1FBQ25DLDJCQUEyQjtzSEFHdEIsdUJBQXVCLFlBcEJ2QjtZQUNMLFlBQVk7WUFDWixrQkFBa0I7WUFDbEIsWUFBWTtZQUNaLGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsaUJBQWlCO1NBQ3BCOzRGQWFRLHVCQUF1QjtrQkFyQm5DLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLFlBQVk7d0JBQ1osa0JBQWtCO3dCQUNsQixZQUFZO3dCQUNaLGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQixpQkFBaUI7cUJBQ3BCO29CQUNELFlBQVksRUFBRTt3QkFDVix5QkFBeUI7d0JBQ3pCLCtCQUErQjt3QkFDL0IsMEJBQTBCO3dCQUMxQixtQ0FBbUM7cUJBQ3RDO29CQUNELE9BQU8sRUFBRTt3QkFDTCwwQkFBMEI7d0JBQzFCLG1DQUFtQzt3QkFDbkMsMkJBQTJCO3FCQUM5QjtpQkFDSiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aUFjdGl2ZVpvbmVNb2R1bGUsIFR1aUxldE1vZHVsZSwgVHVpT2JzY3VyZWRNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtcbiAgICBUdWlEcm9wZG93bk1vZHVsZSxcbiAgICBUdWlEcm9wZG93bk9wdGlvbnNEaXJlY3RpdmUsXG59IGZyb20gJ0B0YWlnYS11aS9jb3JlL2RpcmVjdGl2ZXMvZHJvcGRvd24nO1xuaW1wb3J0IHtQb2x5bW9ycGhldXNNb2R1bGV9IGZyb20gJ0B0aW5rb2ZmL25nLXBvbHltb3JwaGV1cyc7XG5cbmltcG9ydCB7VHVpQWNjZXNzb3JQcm94eURpcmVjdGl2ZX0gZnJvbSAnLi9hY2Nlc3Nvci1wcm94eS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bk9wZW5Nb25pdG9yRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLW9wZW4tbW9uaXRvci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlIb3N0ZWREcm9wZG93bkNvbXBvbmVudH0gZnJvbSAnLi9ob3N0ZWQtZHJvcGRvd24uY29tcG9uZW50JztcbmltcG9ydCB7VHVpSG9zdGVkRHJvcGRvd25Db25uZWN0b3JEaXJlY3RpdmV9IGZyb20gJy4vaG9zdGVkLWRyb3Bkb3duLWNvbm5lY3Rvci5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBQb2x5bW9ycGhldXNNb2R1bGUsXG4gICAgICAgIFR1aUxldE1vZHVsZSxcbiAgICAgICAgVHVpT2JzY3VyZWRNb2R1bGUsXG4gICAgICAgIFR1aUFjdGl2ZVpvbmVNb2R1bGUsXG4gICAgICAgIFR1aURyb3Bkb3duTW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFR1aUFjY2Vzc29yUHJveHlEaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duT3Blbk1vbml0b3JEaXJlY3RpdmUsXG4gICAgICAgIFR1aUhvc3RlZERyb3Bkb3duQ29tcG9uZW50LFxuICAgICAgICBUdWlIb3N0ZWREcm9wZG93bkNvbm5lY3RvckRpcmVjdGl2ZSxcbiAgICBdLFxuICAgIGV4cG9ydHM6IFtcbiAgICAgICAgVHVpSG9zdGVkRHJvcGRvd25Db21wb25lbnQsXG4gICAgICAgIFR1aUhvc3RlZERyb3Bkb3duQ29ubmVjdG9yRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bk9wdGlvbnNEaXJlY3RpdmUsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpSG9zdGVkRHJvcGRvd25Nb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const TUI_HOSTED_DROPDOWN_COMPONENT = new InjectionToken(`[TUI_HOSTED_DROPDOWN_COMPONENT]`);
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaG9zdGVkLWRyb3Bkb3duLnRva2VuLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb21wb25lbnRzL2hvc3RlZC1kcm9wZG93bi9ob3N0ZWQtZHJvcGRvd24udG9rZW4udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUk3QyxNQUFNLENBQUMsTUFBTSw2QkFBNkIsR0FDdEMsSUFBSSxjQUFjLENBQTZCLGlDQUFpQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VufSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHR5cGUge1R1aUhvc3RlZERyb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuL2hvc3RlZC1kcm9wZG93bi5jb21wb25lbnQnO1xuXG5leHBvcnQgY29uc3QgVFVJX0hPU1RFRF9EUk9QRE9XTl9DT01QT05FTlQgPVxuICAgIG5ldyBJbmplY3Rpb25Ub2tlbjxUdWlIb3N0ZWREcm9wZG93bkNvbXBvbmVudD4oYFtUVUlfSE9TVEVEX0RST1BET1dOX0NPTVBPTkVOVF1gKTtcbiJdfQ==
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
export * from './accessor-proxy.directive';
|
|
2
|
+
export * from './dropdown-open-monitor.directive';
|
|
2
3
|
export * from './hosted-dropdown.component';
|
|
3
4
|
export * from './hosted-dropdown.module';
|
|
4
5
|
export * from './hosted-dropdown-connector.directive';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2NvbXBvbmVudHMvaG9zdGVkLWRyb3Bkb3duL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxtQ0FBbUMsQ0FBQztBQUNsRCxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx1Q0FBdUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWNjZXNzb3ItcHJveHkuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24tb3Blbi1tb25pdG9yLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2hvc3RlZC1kcm9wZG93bi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9ob3N0ZWQtZHJvcGRvd24ubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vaG9zdGVkLWRyb3Bkb3duLWNvbm5lY3Rvci5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -27,7 +27,7 @@ export class TuiRootComponent {
|
|
|
27
27
|
}
|
|
28
28
|
}
|
|
29
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.
|
|
30
|
+
TuiRootComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: TuiRootComponent, selector: "tui-root", host: { attributes: { "data-tui-version": "3.41.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<!--TODO: 4.0 rename to tuiOverDropdowns-->\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\"}}@keyframes tuiSkeletonVibe{to{opacity:.5}}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);background:var(--tui-base-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%}.t-overscroll-none{overscroll-behavior:none}\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 });
|
|
31
31
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiRootComponent, decorators: [{
|
|
32
32
|
type: Component,
|
|
33
33
|
args: [{
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/**
|
|
2
|
-
* @deprecated Use {@link https://github.com/
|
|
2
|
+
* @deprecated Use {@link https://github.com/taiga-family/maskito Maskito}
|
|
3
3
|
* TODO: delete in v4.0
|
|
4
4
|
*/
|
|
5
5
|
export const MASK_CARET_TRAP = `[]`;
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFzay1jYXJldC10cmFwLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9jb25zdGFudHMvbWFzay1jYXJldC10cmFwLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBRyxJQUFJLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL3RhaWdhLWZhbWlseS9tYXNraXRvIE1hc2tpdG99XG4gKiBUT0RPOiBkZWxldGUgaW4gdjQuMFxuICovXG5leHBvcnQgY29uc3QgTUFTS19DQVJFVF9UUkFQID0gYFtdYDtcbiJdfQ==
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { Directive, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class TuiDropdownOpenDirective {
|
|
4
|
+
constructor() {
|
|
5
|
+
this.tuiDropdownOpenChange = new EventEmitter();
|
|
6
|
+
}
|
|
7
|
+
set tuiDropdownOpen(open) {
|
|
8
|
+
var _a;
|
|
9
|
+
(_a = this.dropdown) === null || _a === void 0 ? void 0 : _a.toggle(open);
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
TuiDropdownOpenDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownOpenDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
13
|
+
TuiDropdownOpenDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiDropdownOpenDirective, selector: "[tuiDropdownOpen],[tuiDropdownOpenChange]", inputs: { tuiDropdownOpen: "tuiDropdownOpen" }, outputs: { tuiDropdownOpenChange: "tuiDropdownOpenChange" }, ngImport: i0 });
|
|
14
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownOpenDirective, decorators: [{
|
|
15
|
+
type: Directive,
|
|
16
|
+
args: [{
|
|
17
|
+
selector: '[tuiDropdownOpen],[tuiDropdownOpenChange]',
|
|
18
|
+
}]
|
|
19
|
+
}], propDecorators: { tuiDropdownOpen: [{
|
|
20
|
+
type: Input
|
|
21
|
+
}], tuiDropdownOpenChange: [{
|
|
22
|
+
type: Output
|
|
23
|
+
}] } });
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tb3Blbi5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvZHJvcGRvd24vZHJvcGRvd24tb3Blbi5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFPckUsTUFBTSxPQUFPLHdCQUF3QjtJQUhyQztRQVVhLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFXLENBQUM7S0FHaEU7SUFURyxJQUNJLGVBQWUsQ0FBQyxJQUFhOztRQUM3QixNQUFBLElBQUksQ0FBQyxRQUFRLDBDQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUNoQyxDQUFDOztzSEFKUSx3QkFBd0I7MEdBQXhCLHdCQUF3Qjs0RkFBeEIsd0JBQXdCO2tCQUhwQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwyQ0FBMkM7aUJBQ3hEOzhCQUdPLGVBQWU7c0JBRGxCLEtBQUs7Z0JBTUcscUJBQXFCO3NCQUQ3QixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB0eXBlIHtUdWlEcm9wZG93bkRpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1t0dWlEcm9wZG93bk9wZW5dLFt0dWlEcm9wZG93bk9wZW5DaGFuZ2VdJyxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRHJvcGRvd25PcGVuRGlyZWN0aXZlIHtcbiAgICBASW5wdXQoKVxuICAgIHNldCB0dWlEcm9wZG93bk9wZW4ob3BlbjogYm9vbGVhbikge1xuICAgICAgICB0aGlzLmRyb3Bkb3duPy50b2dnbGUob3Blbik7XG4gICAgfVxuXG4gICAgQE91dHB1dCgpXG4gICAgcmVhZG9ubHkgdHVpRHJvcGRvd25PcGVuQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxib29sZWFuPigpO1xuXG4gICAgZHJvcGRvd24/OiBUdWlEcm9wZG93bkRpcmVjdGl2ZTtcbn1cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { Directive, ElementRef, Inject, INJECTOR, Input, Self, } from '@angular/core';
|
|
2
|
+
import { Directive, ElementRef, Inject, INJECTOR, Input, Optional, Self, } from '@angular/core';
|
|
3
3
|
import { TuiDestroyService, TuiDropdownPortalService, tuiPure, } from '@taiga-ui/cdk';
|
|
4
4
|
import { tuiAsRectAccessor, tuiAsVehicle, } from '@taiga-ui/core/abstract';
|
|
5
5
|
import { tuiCheckFixedPosition } from '@taiga-ui/core/utils';
|
|
@@ -7,19 +7,28 @@ import { PolymorpheusComponent } from '@tinkoff/ng-polymorpheus';
|
|
|
7
7
|
import { Subject } from 'rxjs';
|
|
8
8
|
import { takeUntil, throttleTime } from 'rxjs/operators';
|
|
9
9
|
import { TUI_DROPDOWN_COMPONENT } from './dropdown.providers';
|
|
10
|
+
import { TuiDropdownOpenDirective } from './dropdown-open.directive';
|
|
10
11
|
import * as i0 from "@angular/core";
|
|
11
12
|
import * as i1 from "rxjs";
|
|
12
13
|
import * as i2 from "@taiga-ui/cdk";
|
|
14
|
+
import * as i3 from "./dropdown-open.directive";
|
|
13
15
|
export class TuiDropdownDirective {
|
|
14
|
-
constructor(destroy$, el, dropdown, injector, dropdownService) {
|
|
16
|
+
constructor(destroy$, el, dropdown, injector, dropdownService, open) {
|
|
15
17
|
this.el = el;
|
|
16
18
|
this.dropdown = dropdown;
|
|
17
19
|
this.injector = injector;
|
|
18
20
|
this.dropdownService = dropdownService;
|
|
21
|
+
this.open = open;
|
|
19
22
|
this.refresh$ = new Subject();
|
|
20
23
|
this.dropdownBoxRef = null;
|
|
21
24
|
this.type = 'dropdown';
|
|
22
25
|
this.component = new PolymorpheusComponent(this.dropdown, this.injector);
|
|
26
|
+
if (this.open && !this.open.dropdown) {
|
|
27
|
+
this.open.dropdown = this;
|
|
28
|
+
}
|
|
29
|
+
else {
|
|
30
|
+
this.open = null;
|
|
31
|
+
}
|
|
23
32
|
// Ignore multiple change detection triggers at the same frame
|
|
24
33
|
this.refresh$.pipe(throttleTime(0), takeUntil(destroy$)).subscribe(() => {
|
|
25
34
|
var _a, _b;
|
|
@@ -40,21 +49,27 @@ export class TuiDropdownDirective {
|
|
|
40
49
|
}
|
|
41
50
|
ngOnDestroy() {
|
|
42
51
|
this.toggle(false);
|
|
52
|
+
if (this.open) {
|
|
53
|
+
this.open.dropdown = undefined;
|
|
54
|
+
}
|
|
43
55
|
}
|
|
44
56
|
getClientRect() {
|
|
45
57
|
return this.el.nativeElement.getBoundingClientRect();
|
|
46
58
|
}
|
|
47
59
|
toggle(show) {
|
|
60
|
+
var _a, _b;
|
|
48
61
|
if (show && this.content && !this.dropdownBoxRef) {
|
|
49
62
|
this.dropdownBoxRef = this.dropdownService.add(this.component);
|
|
63
|
+
(_a = this.open) === null || _a === void 0 ? void 0 : _a.tuiDropdownOpenChange.emit(true);
|
|
50
64
|
}
|
|
51
65
|
else if (!show && this.dropdownBoxRef) {
|
|
52
66
|
this.dropdownService.remove(this.dropdownBoxRef);
|
|
53
67
|
this.dropdownBoxRef = null;
|
|
68
|
+
(_b = this.open) === null || _b === void 0 ? void 0 : _b.tuiDropdownOpenChange.emit(false);
|
|
54
69
|
}
|
|
55
70
|
}
|
|
56
71
|
}
|
|
57
|
-
TuiDropdownDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownDirective, deps: [{ token: TuiDestroyService, self: true }, { token: ElementRef }, { token: TUI_DROPDOWN_COMPONENT }, { token: INJECTOR }, { token: TuiDropdownPortalService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
72
|
+
TuiDropdownDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownDirective, deps: [{ token: TuiDestroyService, self: true }, { token: ElementRef }, { token: TUI_DROPDOWN_COMPONENT }, { token: INJECTOR }, { token: TuiDropdownPortalService }, { token: TuiDropdownOpenDirective, optional: true }], target: i0.ɵɵFactoryTarget.Directive });
|
|
58
73
|
TuiDropdownDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.17", type: TuiDropdownDirective, selector: "[tuiDropdown]:not(ng-container)", inputs: { content: ["tuiDropdown", "content"] }, providers: [
|
|
59
74
|
TuiDestroyService,
|
|
60
75
|
tuiAsRectAccessor(TuiDropdownDirective),
|
|
@@ -91,8 +106,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
91
106
|
}] }, { type: i2.TuiDropdownPortalService, decorators: [{
|
|
92
107
|
type: Inject,
|
|
93
108
|
args: [TuiDropdownPortalService]
|
|
109
|
+
}] }, { type: i3.TuiDropdownOpenDirective, decorators: [{
|
|
110
|
+
type: Optional
|
|
111
|
+
}, {
|
|
112
|
+
type: Inject,
|
|
113
|
+
args: [TuiDropdownOpenDirective]
|
|
94
114
|
}] }]; }, propDecorators: { content: [{
|
|
95
115
|
type: Input,
|
|
96
116
|
args: ['tuiDropdown']
|
|
97
117
|
}], position: [] } });
|
|
98
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
118
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.directive.js","sourceRoot":"","sources":["../../../../../projects/core/directives/dropdown/dropdown.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewChecked,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    Inject,\n    INJECTOR,\n    Injector,\n    Input,\n    OnChanges,\n    OnDestroy,\n    Optional,\n    Self,\n    Type,\n} from '@angular/core';\nimport {\n    TuiActiveZoneDirective,\n    TuiContextWithImplicit,\n    TuiDestroyService,\n    TuiDropdownPortalService,\n    tuiPure,\n} from '@taiga-ui/cdk';\nimport {\n    tuiAsRectAccessor,\n    tuiAsVehicle,\n    TuiRectAccessor,\n    TuiVehicle,\n} from '@taiga-ui/core/abstract';\nimport {TuiPortalItem} from '@taiga-ui/core/interfaces';\nimport {tuiCheckFixedPosition} from '@taiga-ui/core/utils';\nimport {PolymorpheusComponent, PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable, Subject} from 'rxjs';\nimport {takeUntil, throttleTime} from 'rxjs/operators';\n\nimport {TUI_DROPDOWN_COMPONENT} from './dropdown.providers';\nimport {TuiDropdownOpenDirective} from './dropdown-open.directive';\n\n@Directive({\n    selector: '[tuiDropdown]:not(ng-container)',\n    exportAs: 'tuiDropdown',\n    providers: [\n        TuiDestroyService,\n        tuiAsRectAccessor(TuiDropdownDirective),\n        tuiAsVehicle(TuiDropdownDirective),\n    ],\n})\nexport class TuiDropdownDirective\n    implements\n        AfterViewChecked,\n        OnDestroy,\n        OnChanges,\n        TuiPortalItem,\n        TuiRectAccessor,\n        TuiVehicle\n{\n    private readonly refresh$ = new Subject<void>();\n\n    @Input('tuiDropdown')\n    content: PolymorpheusContent<TuiContextWithImplicit<TuiActiveZoneDirective>>;\n\n    dropdownBoxRef: ComponentRef<unknown> | null = null;\n\n    readonly type = 'dropdown';\n\n    readonly component = new PolymorpheusComponent(this.dropdown, this.injector);\n\n    constructor(\n        @Self() @Inject(TuiDestroyService) destroy$: Observable<unknown>,\n        @Inject(ElementRef) readonly el: ElementRef<HTMLElement>,\n        @Inject(TUI_DROPDOWN_COMPONENT) private readonly dropdown: Type<unknown>,\n        @Inject(INJECTOR) private readonly injector: Injector,\n        @Inject(TuiDropdownPortalService)\n        private readonly dropdownService: TuiDropdownPortalService,\n        @Optional()\n        @Inject(TuiDropdownOpenDirective)\n        private readonly open: TuiDropdownOpenDirective | null,\n    ) {\n        if (this.open && !this.open.dropdown) {\n            this.open.dropdown = this;\n        } else {\n            this.open = null;\n        }\n\n        // Ignore multiple change detection triggers at the same frame\n        this.refresh$.pipe(throttleTime(0), takeUntil(destroy$)).subscribe(() => {\n            this.dropdownBoxRef?.changeDetectorRef.detectChanges();\n            this.dropdownBoxRef?.changeDetectorRef.markForCheck();\n        });\n    }\n\n    @tuiPure\n    get position(): 'absolute' | 'fixed' {\n        return tuiCheckFixedPosition(this.el.nativeElement) ? 'fixed' : 'absolute';\n    }\n\n    ngAfterViewChecked(): void {\n        this.refresh$.next();\n    }\n\n    ngOnChanges(): void {\n        if (!this.content) {\n            this.toggle(false);\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.toggle(false);\n\n        if (this.open) {\n            this.open.dropdown = undefined;\n        }\n    }\n\n    getClientRect(): ClientRect {\n        return this.el.nativeElement.getBoundingClientRect();\n    }\n\n    toggle(show: boolean): void {\n        if (show && this.content && !this.dropdownBoxRef) {\n            this.dropdownBoxRef = this.dropdownService.add(this.component);\n            this.open?.tuiDropdownOpenChange.emit(true);\n        } else if (!show && this.dropdownBoxRef) {\n            this.dropdownService.remove(this.dropdownBoxRef);\n            this.dropdownBoxRef = null;\n            this.open?.tuiDropdownOpenChange.emit(false);\n        }\n    }\n}\n"]}
|
|
@@ -9,6 +9,7 @@ import { TuiDropdownDriverDirective } from './dropdown-driver.directive';
|
|
|
9
9
|
import { TuiDropdownHostDirective } from './dropdown-host.directive';
|
|
10
10
|
import { TuiDropdownHoverDirective } from './dropdown-hover.directive';
|
|
11
11
|
import { TuiDropdownManualDirective } from './dropdown-manual.directive';
|
|
12
|
+
import { TuiDropdownOpenDirective } from './dropdown-open.directive';
|
|
12
13
|
import { TuiDropdownOptionsDirective } from './dropdown-options.directive';
|
|
13
14
|
import { TuiDropdownPositionDirective } from './dropdown-position.directive';
|
|
14
15
|
import { TuiDropdownPositionSidedDirective } from './dropdown-position-sided.directive';
|
|
@@ -19,6 +20,7 @@ export class TuiDropdownModule {
|
|
|
19
20
|
TuiDropdownModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
20
21
|
TuiDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: TuiDropdownModule, declarations: [TuiDropdownDirective,
|
|
21
22
|
TuiDropdownComponent,
|
|
23
|
+
TuiDropdownOpenDirective,
|
|
22
24
|
TuiDropdownOptionsDirective,
|
|
23
25
|
TuiDropdownHostDirective,
|
|
24
26
|
TuiDropdownDriverDirective,
|
|
@@ -33,6 +35,7 @@ TuiDropdownModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", versi
|
|
|
33
35
|
TuiScrollbarModule,
|
|
34
36
|
TuiHoveredModule], exports: [TuiDropdownDirective,
|
|
35
37
|
TuiDropdownComponent,
|
|
38
|
+
TuiDropdownOpenDirective,
|
|
36
39
|
TuiDropdownOptionsDirective,
|
|
37
40
|
TuiDropdownHostDirective,
|
|
38
41
|
TuiDropdownDriverDirective,
|
|
@@ -62,6 +65,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
62
65
|
declarations: [
|
|
63
66
|
TuiDropdownDirective,
|
|
64
67
|
TuiDropdownComponent,
|
|
68
|
+
TuiDropdownOpenDirective,
|
|
65
69
|
TuiDropdownOptionsDirective,
|
|
66
70
|
TuiDropdownHostDirective,
|
|
67
71
|
TuiDropdownDriverDirective,
|
|
@@ -75,6 +79,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
75
79
|
exports: [
|
|
76
80
|
TuiDropdownDirective,
|
|
77
81
|
TuiDropdownComponent,
|
|
82
|
+
TuiDropdownOpenDirective,
|
|
78
83
|
TuiDropdownOptionsDirective,
|
|
79
84
|
TuiDropdownHostDirective,
|
|
80
85
|
TuiDropdownDriverDirective,
|
|
@@ -87,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
87
92
|
],
|
|
88
93
|
}]
|
|
89
94
|
}] });
|
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
95
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24ubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL2Ryb3Bkb3duL2Ryb3Bkb3duLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsUUFBUSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3ZDLE9BQU8sRUFBQyxtQkFBbUIsRUFBRSxnQkFBZ0IsRUFBRSxtQkFBbUIsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN6RixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN2RSxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUU1RCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRCxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSxzQkFBc0IsQ0FBQztBQUMxRCxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN6RSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUNyRSxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSw2QkFBNkIsQ0FBQztBQUN2RSxPQUFPLEVBQUMsd0JBQXdCLEVBQUMsTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUMsMkJBQTJCLEVBQUMsTUFBTSw4QkFBOEIsQ0FBQztBQUN6RSxPQUFPLEVBQUMsNEJBQTRCLEVBQUMsTUFBTSwrQkFBK0IsQ0FBQztBQUMzRSxPQUFPLEVBQUMsaUNBQWlDLEVBQUMsTUFBTSxxQ0FBcUMsQ0FBQztBQUN0RixPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSxnQ0FBZ0MsQ0FBQzs7QUF1QzdFLE1BQU0sT0FBTyxpQkFBaUI7OytHQUFqQixpQkFBaUI7Z0hBQWpCLGlCQUFpQixpQkE1QnRCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsd0JBQXdCO1FBQ3hCLDJCQUEyQjtRQUMzQix3QkFBd0I7UUFDeEIsMEJBQTBCO1FBQzFCLDBCQUEwQjtRQUMxQix5QkFBeUI7UUFDekIsMkJBQTJCO1FBQzNCLDRCQUE0QjtRQUM1QixpQ0FBaUM7UUFDakMsNkJBQTZCLGFBbEI3QixrQkFBa0I7UUFDbEIsbUJBQW1CO1FBQ25CLG1CQUFtQjtRQUNuQixrQkFBa0I7UUFDbEIsZ0JBQWdCLGFBaUJoQixvQkFBb0I7UUFDcEIsb0JBQW9CO1FBQ3BCLHdCQUF3QjtRQUN4QiwyQkFBMkI7UUFDM0Isd0JBQXdCO1FBQ3hCLDBCQUEwQjtRQUMxQiwwQkFBMEI7UUFDMUIseUJBQXlCO1FBQ3pCLDJCQUEyQjtRQUMzQiw0QkFBNEI7UUFDNUIsaUNBQWlDO1FBQ2pDLDZCQUE2QjtnSEFHeEIsaUJBQWlCLFlBcENqQjtZQUNMLGtCQUFrQjtZQUNsQixtQkFBbUI7WUFDbkIsbUJBQW1CO1lBQ25CLGtCQUFrQjtZQUNsQixnQkFBZ0I7U0FDbkI7NEZBOEJRLGlCQUFpQjtrQkFyQzdCLFFBQVE7bUJBQUM7b0JBQ04sT0FBTyxFQUFFO3dCQUNMLGtCQUFrQjt3QkFDbEIsbUJBQW1CO3dCQUNuQixtQkFBbUI7d0JBQ25CLGtCQUFrQjt3QkFDbEIsZ0JBQWdCO3FCQUNuQjtvQkFDRCxZQUFZLEVBQUU7d0JBQ1Ysb0JBQW9CO3dCQUNwQixvQkFBb0I7d0JBQ3BCLHdCQUF3Qjt3QkFDeEIsMkJBQTJCO3dCQUMzQix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsMEJBQTBCO3dCQUMxQix5QkFBeUI7d0JBQ3pCLDJCQUEyQjt3QkFDM0IsNEJBQTRCO3dCQUM1QixpQ0FBaUM7d0JBQ2pDLDZCQUE2QjtxQkFDaEM7b0JBQ0QsT0FBTyxFQUFFO3dCQUNMLG9CQUFvQjt3QkFDcEIsb0JBQW9CO3dCQUNwQix3QkFBd0I7d0JBQ3hCLDJCQUEyQjt3QkFDM0Isd0JBQXdCO3dCQUN4QiwwQkFBMEI7d0JBQzFCLDBCQUEwQjt3QkFDMUIseUJBQXlCO3dCQUN6QiwyQkFBMkI7d0JBQzNCLDRCQUE0Qjt3QkFDNUIsaUNBQWlDO3dCQUNqQyw2QkFBNkI7cUJBQ2hDO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtOZ01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1R1aUFjdGl2ZVpvbmVNb2R1bGUsIFR1aUhvdmVyZWRNb2R1bGUsIFR1aU92ZXJzY3JvbGxNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUdWlTY3JvbGxiYXJNb2R1bGV9IGZyb20gJ0B0YWlnYS11aS9jb3JlL2NvbXBvbmVudHMvc2Nyb2xsYmFyJztcbmltcG9ydCB7UG9seW1vcnBoZXVzTW9kdWxlfSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuXG5pbXBvcnQge1R1aURyb3Bkb3duQ29tcG9uZW50fSBmcm9tICcuL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG5pbXBvcnQge1R1aURyb3Bkb3duRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duQ29udGV4dERpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi1jb250ZXh0LmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duRHJpdmVyRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLWRyaXZlci5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkhvc3REaXJlY3RpdmV9IGZyb20gJy4vZHJvcGRvd24taG9zdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bkhvdmVyRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLWhvdmVyLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duTWFudWFsRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLW1hbnVhbC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bk9wZW5EaXJlY3RpdmV9IGZyb20gJy4vZHJvcGRvd24tb3Blbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93bk9wdGlvbnNEaXJlY3RpdmV9IGZyb20gJy4vZHJvcGRvd24tb3B0aW9ucy5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93blBvc2l0aW9uRGlyZWN0aXZlfSBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLmRpcmVjdGl2ZSc7XG5pbXBvcnQge1R1aURyb3Bkb3duUG9zaXRpb25TaWRlZERpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi1wb3NpdGlvbi1zaWRlZC5kaXJlY3RpdmUnO1xuaW1wb3J0IHtUdWlEcm9wZG93blNlbGVjdGlvbkRpcmVjdGl2ZX0gZnJvbSAnLi9kcm9wZG93bi1zZWxlY3Rpb24uZGlyZWN0aXZlJztcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbXG4gICAgICAgIFBvbHltb3JwaGV1c01vZHVsZSxcbiAgICAgICAgVHVpQWN0aXZlWm9uZU1vZHVsZSxcbiAgICAgICAgVHVpT3ZlcnNjcm9sbE1vZHVsZSxcbiAgICAgICAgVHVpU2Nyb2xsYmFyTW9kdWxlLFxuICAgICAgICBUdWlIb3ZlcmVkTW9kdWxlLFxuICAgIF0sXG4gICAgZGVjbGFyYXRpb25zOiBbXG4gICAgICAgIFR1aURyb3Bkb3duRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkNvbXBvbmVudCxcbiAgICAgICAgVHVpRHJvcGRvd25PcGVuRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bk9wdGlvbnNEaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duSG9zdERpcmVjdGl2ZSxcbiAgICAgICAgVHVpRHJvcGRvd25Ecml2ZXJEaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duTWFudWFsRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkhvdmVyRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkNvbnRleHREaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duUG9zaXRpb25EaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duUG9zaXRpb25TaWRlZERpcmVjdGl2ZSxcbiAgICAgICAgVHVpRHJvcGRvd25TZWxlY3Rpb25EaXJlY3RpdmUsXG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIFR1aURyb3Bkb3duRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkNvbXBvbmVudCxcbiAgICAgICAgVHVpRHJvcGRvd25PcGVuRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bk9wdGlvbnNEaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duSG9zdERpcmVjdGl2ZSxcbiAgICAgICAgVHVpRHJvcGRvd25Ecml2ZXJEaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duTWFudWFsRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkhvdmVyRGlyZWN0aXZlLFxuICAgICAgICBUdWlEcm9wZG93bkNvbnRleHREaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duUG9zaXRpb25EaXJlY3RpdmUsXG4gICAgICAgIFR1aURyb3Bkb3duUG9zaXRpb25TaWRlZERpcmVjdGl2ZSxcbiAgICAgICAgVHVpRHJvcGRvd25TZWxlY3Rpb25EaXJlY3RpdmUsXG4gICAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVHVpRHJvcGRvd25Nb2R1bGUge31cbiJdfQ==
|
|
@@ -8,8 +8,9 @@ export * from './dropdown-host.directive';
|
|
|
8
8
|
export * from './dropdown-hover.directive';
|
|
9
9
|
export * from './dropdown-hover.options.directive';
|
|
10
10
|
export * from './dropdown-manual.directive';
|
|
11
|
+
export * from './dropdown-open.directive';
|
|
11
12
|
export * from './dropdown-options.directive';
|
|
12
13
|
export * from './dropdown-position.directive';
|
|
13
14
|
export * from './dropdown-position-sided.directive';
|
|
14
15
|
export * from './dropdown-selection.directive';
|
|
15
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb3JlL2RpcmVjdGl2ZXMvZHJvcGRvd24vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDRCQUE0QixDQUFDO0FBQzNDLGNBQWMsb0NBQW9DLENBQUM7QUFDbkQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHFDQUFxQyxDQUFDO0FBQ3BELGNBQWMsZ0NBQWdDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLnByb3ZpZGVycyc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLWNvbnRleHQuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24tZHJpdmVyLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLWhvc3QuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24taG92ZXIuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24taG92ZXIub3B0aW9ucy5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1tYW51YWwuZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vZHJvcGRvd24tb3Blbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9kcm9wZG93bi1vcHRpb25zLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXBvc2l0aW9uLXNpZGVkLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLXNlbGVjdGlvbi5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -9,7 +9,7 @@ export class TuiTextfieldAppearanceDirective extends AbstractTuiController {
|
|
|
9
9
|
constructor() {
|
|
10
10
|
super(...arguments);
|
|
11
11
|
// it's an empty string by default for backward compatibility
|
|
12
|
-
// (see comment https://github.com/
|
|
12
|
+
// (see comment https://github.com/taiga-family/taiga-ui/pull/3007#issuecomment-1315179508)
|
|
13
13
|
this.appearance = '';
|
|
14
14
|
}
|
|
15
15
|
}
|
|
@@ -35,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImpo
|
|
|
35
35
|
type: Input,
|
|
36
36
|
args: ['tuiTextfieldAppearance']
|
|
37
37
|
}] } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dGZpZWxkLWFwcGVhcmFuY2UuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29yZS9kaXJlY3RpdmVzL3RleHRmaWVsZC1jb250cm9sbGVyL3RleHRmaWVsZC1hcHBlYXJhbmNlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLFVBQVUsRUFBRSxjQUFjLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQzNFLE9BQU8sRUFBQyxxQkFBcUIsRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFFcEQsaURBQWlEO0FBQ2pELE1BQU0sQ0FBQyxNQUFNLGtDQUFrQyxHQUMzQyxJQUFJLGNBQWMsQ0FDZCxzQ0FBc0MsRUFDdEM7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSwrQkFBK0IsRUFBRTtDQUN2RCxDQUNKLENBQUM7QUFXTixNQUFNLE9BQU8sK0JBQWdDLFNBQVEscUJBQXFCO0lBVDFFOztRQVVJLDZEQUE2RDtRQUM3RCwyRkFBMkY7UUFFM0YsZUFBVSxHQUFHLEVBQUUsQ0FBQztLQUNuQjs7NkhBTFksK0JBQStCO2lIQUEvQiwrQkFBK0IscUhBUDdCO1FBQ1A7WUFDSSxPQUFPLEVBQUUsa0NBQWtDO1lBQzNDLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsK0JBQStCLENBQUM7U0FDakU7S0FDSjs0RkFFUSwrQkFBK0I7a0JBVDNDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDBCQUEwQjtvQkFDcEMsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxrQ0FBa0M7NEJBQzNDLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLGdDQUFnQyxDQUFDO3lCQUNqRTtxQkFDSjtpQkFDSjs4QkFLRyxVQUFVO3NCQURULEtBQUs7dUJBQUMsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIGZvcndhcmRSZWYsIEluamVjdGlvblRva2VuLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Fic3RyYWN0VHVpQ29udHJvbGxlcn0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbi8vIFRPRE86IHJlbmFtZSB0byBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0UgaW4gdjRcbmV4cG9ydCBjb25zdCBUVUlfVEVYVEZJRUxEX0FQUEVBUkFOQ0VfRElSRUNUSVZFID1cbiAgICBuZXcgSW5qZWN0aW9uVG9rZW48VHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZT4oXG4gICAgICAgICdbVFVJX1RFWFRGSUVMRF9BUFBFQVJBTkNFX0RJUkVDVElWRV0nLFxuICAgICAgICB7XG4gICAgICAgICAgICBmYWN0b3J5OiAoKSA9PiBuZXcgVHVpVGV4dGZpZWxkQXBwZWFyYW5jZURpcmVjdGl2ZSgpLFxuICAgICAgICB9LFxuICAgICk7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3R1aVRleHRmaWVsZEFwcGVhcmFuY2VdJyxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogVFVJX1RFWFRGSUVMRF9BUFBFQVJBTkNFX0RJUkVDVElWRSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUpLFxuICAgICAgICB9LFxuICAgIF0sXG59KVxuZXhwb3J0IGNsYXNzIFR1aVRleHRmaWVsZEFwcGVhcmFuY2VEaXJlY3RpdmUgZXh0ZW5kcyBBYnN0cmFjdFR1aUNvbnRyb2xsZXIge1xuICAgIC8vIGl0J3MgYW4gZW1wdHkgc3RyaW5nIGJ5IGRlZmF1bHQgZm9yIGJhY2t3YXJkIGNvbXBhdGliaWxpdHlcbiAgICAvLyAoc2VlIGNvbW1lbnQgaHR0cHM6Ly9naXRodWIuY29tL3RhaWdhLWZhbWlseS90YWlnYS11aS9wdWxsLzMwMDcjaXNzdWVjb21tZW50LTEzMTUxNzk1MDgpXG4gICAgQElucHV0KCd0dWlUZXh0ZmllbGRBcHBlYXJhbmNlJylcbiAgICBhcHBlYXJhbmNlID0gJyc7XG59XG4iXX0=
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1tYXNrLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2NvcmUvbWFzay90ZXh0LW1hc2stY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBkZXByZWNhdGVkIFVzZSB7QGxpbmsgaHR0cHM6Ly9naXRodWIuY29tL3RhaWdhLWZhbWlseS9tYXNraXRvIE1hc2tpdG99XG4gKiBMaW5rIGxpZXMgYWJvdXQgY29uZmlnIG9iamVjdCBoYXZpbmcgYWxsIHRoZSBzYW1lIGNvbmZpZ3VyYXRpb25zIHNvIHNlcGFyYXRlIGludGVyZmFjZSBpcyByZXF1aXJlZFxuICoge0BsaW5rIGh0dHBzOi8vZ2l0aHViLmNvbS90ZXh0LW1hc2svdGV4dC1tYXNrL2Jsb2IvbWFzdGVyL2NvbXBvbmVudERvY3VtZW50YXRpb24ubWQjcGlwZX1cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUdWlUZXh0TWFza0NvbmZpZyB7XG4gICAgcmVhZG9ubHkgcmF3VmFsdWU6IHN0cmluZztcbiAgICByZWFkb25seSBwcmV2aW91c0NvbmZvcm1lZFZhbHVlPzogc3RyaW5nO1xuICAgIHJlYWRvbmx5IGN1cnJlbnRDYXJldFBvc2l0aW9uPzogbnVtYmVyO1xufVxuIl19
|