@taiga-ui/kit 3.7.1 → 3.9.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-kit-components-action.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-action.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-avatar.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-avatar.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-month.umd.js +0 -3
- package/bundles/taiga-ui-kit-components-input-month.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-tag.umd.js +17 -4
- package/bundles/taiga-ui-kit-components-input-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-input-year.umd.js +540 -0
- package/bundles/taiga-ui-kit-components-input-year.umd.js.map +1 -0
- package/bundles/taiga-ui-kit-components-line-clamp.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-line-clamp.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-marker-icon.umd.js +2 -2
- package/bundles/taiga-ui-kit-components-marker-icon.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-multi-select-option.umd.js +3 -2
- package/bundles/taiga-ui-kit-components-multi-select-option.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-multi-select.umd.js +11 -15
- package/bundles/taiga-ui-kit-components-multi-select.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js +16 -3
- package/bundles/taiga-ui-kit-components-pdf-viewer.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-push.umd.js +13 -2
- package/bundles/taiga-ui-kit-components-push.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-select.umd.js +251 -27
- package/bundles/taiga-ui-kit-components-select.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-stepper.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-stepper.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-tag.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-tag.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components-text-area.umd.js +1 -1
- package/bundles/taiga-ui-kit-components-text-area.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-components.umd.js +10 -4
- package/bundles/taiga-ui-kit-components.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-pipes-to-year.umd.js +70 -0
- package/bundles/taiga-ui-kit-pipes-to-year.umd.js.map +1 -0
- package/bundles/taiga-ui-kit-pipes.umd.js +10 -4
- package/bundles/taiga-ui-kit-pipes.umd.js.map +1 -1
- package/bundles/taiga-ui-kit-tokens.umd.js +4 -0
- package/bundles/taiga-ui-kit-tokens.umd.js.map +1 -1
- package/components/avatar/avatar-options.d.ts +2 -2
- package/components/avatar/avatar.component.d.ts +1 -1
- package/components/index.d.ts +1 -0
- package/components/input-month/input-month.component.d.ts +0 -1
- package/components/input-tag/input-tag.component.d.ts +3 -0
- package/components/input-year/index.d.ts +3 -0
- package/components/input-year/input-year.component.d.ts +30 -0
- package/components/input-year/input-year.directive.d.ts +9 -0
- package/components/input-year/input-year.module.d.ts +12 -0
- package/components/input-year/package.json +10 -0
- package/components/input-year/taiga-ui-kit-components-input-year.d.ts +5 -0
- package/components/marker-icon/marker-icon.component.d.ts +3 -3
- package/components/multi-select/multi-select-group/multi-select-group.component.d.ts +4 -2
- package/components/multi-select/multi-select.module.d.ts +1 -1
- package/components/pdf-viewer/index.d.ts +1 -0
- package/components/pdf-viewer/pdf-viewer.tokens.d.ts +10 -0
- package/components/push/index.d.ts +1 -0
- package/components/push/push.options.d.ts +0 -1
- package/components/push/push.tokens.d.ts +5 -0
- package/components/select/index.d.ts +3 -0
- package/components/select/native-select/native-select-group.component.d.ts +8 -0
- package/components/select/native-select/native-select.component.d.ts +7 -0
- package/components/select/native-select/native-select.d.ts +14 -0
- package/components/select/select.component.d.ts +7 -4
- package/components/select/select.module.d.ts +10 -7
- package/esm2015/components/action/action.component.js +1 -1
- package/esm2015/components/avatar/avatar-options.js +1 -1
- package/esm2015/components/avatar/avatar.component.js +1 -1
- package/esm2015/components/index.js +2 -1
- package/esm2015/components/input-month/input-month.component.js +1 -4
- package/esm2015/components/input-tag/input-tag.component.js +18 -6
- package/esm2015/components/input-year/index.js +4 -0
- package/esm2015/components/input-year/input-year.component.js +102 -0
- package/esm2015/components/input-year/input-year.directive.js +21 -0
- package/esm2015/components/input-year/input-year.module.js +44 -0
- package/esm2015/components/input-year/taiga-ui-kit-components-input-year.js +5 -0
- package/esm2015/components/line-clamp/line-clamp-box.component.js +2 -2
- package/esm2015/components/marker-icon/marker-icon.component.js +3 -3
- package/esm2015/components/multi-select/multi-select-group/multi-select-group.component.js +11 -10
- package/esm2015/components/multi-select/multi-select.module.js +5 -5
- package/esm2015/components/multi-select-option/multi-select-option.component.js +4 -3
- package/esm2015/components/pdf-viewer/index.js +2 -1
- package/esm2015/components/pdf-viewer/pdf-viewer.component.js +2 -2
- package/esm2015/components/pdf-viewer/pdf-viewer.service.js +4 -4
- package/esm2015/components/pdf-viewer/pdf-viewer.tokens.js +12 -0
- package/esm2015/components/push/index.js +2 -1
- package/esm2015/components/push/push.component.js +2 -2
- package/esm2015/components/push/push.options.js +2 -10
- package/esm2015/components/push/push.service.js +4 -4
- package/esm2015/components/push/push.tokens.js +20 -0
- package/esm2015/components/select/index.js +4 -1
- package/esm2015/components/select/native-select/native-select-group.component.js +69 -0
- package/esm2015/components/select/native-select/native-select.component.js +66 -0
- package/esm2015/components/select/native-select/native-select.js +38 -0
- package/esm2015/components/select/select.component.js +19 -5
- package/esm2015/components/select/select.module.js +33 -6
- package/esm2015/components/stepper/stepper.component.js +1 -1
- package/esm2015/components/tag/tag.component.js +1 -1
- package/esm2015/components/text-area/text-area.component.js +1 -1
- package/esm2015/pipes/index.js +2 -1
- package/esm2015/pipes/to-year/index.js +3 -0
- package/esm2015/pipes/to-year/taiga-ui-kit-pipes-to-year.js +5 -0
- package/esm2015/pipes/to-year/to-year.module.js +16 -0
- package/esm2015/pipes/to-year/to-year.pipe.js +17 -0
- package/esm2015/tokens/i18n.js +4 -1
- package/fesm2015/taiga-ui-kit-components-action.js +1 -1
- package/fesm2015/taiga-ui-kit-components-action.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-avatar.js +1 -1
- package/fesm2015/taiga-ui-kit-components-avatar.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-month.js +0 -3
- package/fesm2015/taiga-ui-kit-components-input-month.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-tag.js +17 -5
- package/fesm2015/taiga-ui-kit-components-input-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-input-year.js +165 -0
- package/fesm2015/taiga-ui-kit-components-input-year.js.map +1 -0
- package/fesm2015/taiga-ui-kit-components-line-clamp.js +1 -1
- package/fesm2015/taiga-ui-kit-components-line-clamp.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-marker-icon.js +2 -2
- package/fesm2015/taiga-ui-kit-components-marker-icon.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-multi-select-option.js +3 -2
- package/fesm2015/taiga-ui-kit-components-multi-select-option.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-multi-select.js +13 -13
- package/fesm2015/taiga-ui-kit-components-multi-select.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-pdf-viewer.js +15 -5
- package/fesm2015/taiga-ui-kit-components-pdf-viewer.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-push.js +13 -4
- package/fesm2015/taiga-ui-kit-components-push.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-select.js +210 -17
- package/fesm2015/taiga-ui-kit-components-select.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-stepper.js +1 -1
- package/fesm2015/taiga-ui-kit-components-stepper.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-tag.js +1 -1
- package/fesm2015/taiga-ui-kit-components-tag.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components-text-area.js +1 -1
- package/fesm2015/taiga-ui-kit-components-text-area.js.map +1 -1
- package/fesm2015/taiga-ui-kit-components.js +1 -0
- package/fesm2015/taiga-ui-kit-components.js.map +1 -1
- package/fesm2015/taiga-ui-kit-pipes-to-year.js +37 -0
- package/fesm2015/taiga-ui-kit-pipes-to-year.js.map +1 -0
- package/fesm2015/taiga-ui-kit-pipes.js +1 -0
- package/fesm2015/taiga-ui-kit-pipes.js.map +1 -1
- package/fesm2015/taiga-ui-kit-tokens.js +4 -1
- package/fesm2015/taiga-ui-kit-tokens.js.map +1 -1
- package/package.json +4 -4
- package/pipes/index.d.ts +1 -0
- package/pipes/to-year/index.d.ts +2 -0
- package/pipes/to-year/package.json +10 -0
- package/pipes/to-year/taiga-ui-kit-pipes-to-year.d.ts +5 -0
- package/pipes/to-year/to-year.module.d.ts +7 -0
- package/pipes/to-year/to-year.pipe.d.ts +8 -0
- package/tokens/i18n.d.ts +4 -0
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
2
|
import { AbstractTuiDialogService } from '@taiga-ui/cdk';
|
|
3
3
|
import { PolymorpheusComponent } from '@tinkoff/ng-polymorpheus';
|
|
4
4
|
import { TuiPdfViewerComponent } from './pdf-viewer.component';
|
|
5
|
+
import { TUI_PDF_VIEWER_OPTIONS } from './pdf-viewer.tokens';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
const DIALOG = new PolymorpheusComponent(TuiPdfViewerComponent);
|
|
7
|
-
const DEFAULT_OPTIONS = { label: ``, actions: `` };
|
|
8
8
|
export class TuiPdfViewerService extends AbstractTuiDialogService {
|
|
9
9
|
constructor() {
|
|
10
10
|
super(...arguments);
|
|
11
11
|
this.component = DIALOG;
|
|
12
|
-
this.defaultOptions =
|
|
12
|
+
this.defaultOptions = Object.assign(Object.assign({}, inject(TUI_PDF_VIEWER_OPTIONS)), { data: undefined });
|
|
13
13
|
}
|
|
14
14
|
open(content, options = {}) {
|
|
15
15
|
return super.open(content, options);
|
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
23
23
|
providedIn: `root`,
|
|
24
24
|
}]
|
|
25
25
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRmLXZpZXdlci5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcGRmLXZpZXdlci9wZGYtdmlld2VyLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFDLHdCQUF3QixFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUMscUJBQXFCLEVBQXNCLE1BQU0sMEJBQTBCLENBQUM7QUFHcEYsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDN0QsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0scUJBQXFCLENBQUM7O0FBRzNELE1BQU0sTUFBTSxHQUFHLElBQUkscUJBQXFCLENBQUMscUJBQXFCLENBQUMsQ0FBQztBQVNoRSxNQUFNLE9BQU8sbUJBQW9CLFNBQVEsd0JBRXhDO0lBTEQ7O1FBTXVCLGNBQVMsR0FBRyxNQUFNLENBQUM7UUFDbkIsbUJBQWMsbUNBQzFCLE1BQU0sQ0FBQyxzQkFBc0IsQ0FBQyxLQUNqQyxJQUFJLEVBQUUsU0FBUyxJQUNqQjtLQVFMO0lBTlksSUFBSSxDQUNULE9BQXFDLEVBQ3JDLFVBQTZDLEVBQUU7UUFFL0MsT0FBTyxLQUFLLENBQUMsSUFBSSxDQUFDLE9BQXFCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDdEQsQ0FBQzs7aUhBZFEsbUJBQW1CO3FIQUFuQixtQkFBbUIsY0FGaEIsTUFBTTs0RkFFVCxtQkFBbUI7a0JBSC9CLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtpbmplY3QsIEluamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTYWZlUmVzb3VyY2VVcmx9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHtBYnN0cmFjdFR1aURpYWxvZ1NlcnZpY2UsIFR1aUJhc2VEaWFsb2dDb250ZXh0fSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29tcG9uZW50LCBQb2x5bW9ycGhldXNDb250ZW50fSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHtUdWlQZGZWaWV3ZXJDb21wb25lbnR9IGZyb20gJy4vcGRmLXZpZXdlci5jb21wb25lbnQnO1xuaW1wb3J0IHtUVUlfUERGX1ZJRVdFUl9PUFRJT05TfSBmcm9tICcuL3BkZi12aWV3ZXIudG9rZW5zJztcbmltcG9ydCB7VHVpUGRmVmlld2VyT3B0aW9uc30gZnJvbSAnLi9wZGYtdmlld2VyLW9wdGlvbnMnO1xuXG5jb25zdCBESUFMT0cgPSBuZXcgUG9seW1vcnBoZXVzQ29tcG9uZW50KFR1aVBkZlZpZXdlckNvbXBvbmVudCk7XG5cbnR5cGUgQ29udGVudDxHPiA9IFBvbHltb3JwaGV1c0NvbnRlbnQ8XG4gICAgVHVpQmFzZURpYWxvZ0NvbnRleHQ8Rz4gJiBUdWlQZGZWaWV3ZXJPcHRpb25zPHVua25vd24+XG4+O1xuXG5ASW5qZWN0YWJsZSh7XG4gICAgcHJvdmlkZWRJbjogYHJvb3RgLFxufSlcbmV4cG9ydCBjbGFzcyBUdWlQZGZWaWV3ZXJTZXJ2aWNlIGV4dGVuZHMgQWJzdHJhY3RUdWlEaWFsb2dTZXJ2aWNlPFxuICAgIFR1aVBkZlZpZXdlck9wdGlvbnM8dW5rbm93bj5cbj4ge1xuICAgIHByb3RlY3RlZCByZWFkb25seSBjb21wb25lbnQgPSBESUFMT0c7XG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IGRlZmF1bHRPcHRpb25zOiBUdWlQZGZWaWV3ZXJPcHRpb25zPHVua25vd24+ID0ge1xuICAgICAgICAuLi5pbmplY3QoVFVJX1BERl9WSUVXRVJfT1BUSU9OUyksXG4gICAgICAgIGRhdGE6IHVuZGVmaW5lZCxcbiAgICB9O1xuXG4gICAgb3ZlcnJpZGUgb3BlbjxHPihcbiAgICAgICAgY29udGVudDogU2FmZVJlc291cmNlVXJsIHwgQ29udGVudDxHPixcbiAgICAgICAgb3B0aW9uczogUGFydGlhbDxUdWlQZGZWaWV3ZXJPcHRpb25zPGFueT4+ID0ge30sXG4gICAgKTogT2JzZXJ2YWJsZTxHPiB7XG4gICAgICAgIHJldHVybiBzdXBlci5vcGVuKGNvbnRlbnQgYXMgQ29udGVudDxHPiwgb3B0aW9ucyk7XG4gICAgfVxufVxuIl19
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const TUI_PDF_VIEWER_DEFAULT_OPTIONS = { label: ``, actions: `` };
|
|
3
|
+
export const TUI_PDF_VIEWER_OPTIONS = new InjectionToken(`[TUI_PDF_VIEWER_OPTIONS]: Default parameters for pdf viewer component`, {
|
|
4
|
+
factory: () => TUI_PDF_VIEWER_DEFAULT_OPTIONS,
|
|
5
|
+
});
|
|
6
|
+
export function tuiPdfViewerOptionsProvider(options) {
|
|
7
|
+
return {
|
|
8
|
+
provide: TUI_PDF_VIEWER_OPTIONS,
|
|
9
|
+
useValue: Object.assign(Object.assign({}, TUI_PDF_VIEWER_DEFAULT_OPTIONS), options),
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGRmLXZpZXdlci50b2tlbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wZGYtdmlld2VyL3BkZi12aWV3ZXIudG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQWdCLE1BQU0sZUFBZSxDQUFDO0FBTTVELE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFHLEVBQUMsS0FBSyxFQUFFLEVBQUUsRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFDLENBQUM7QUFFdkUsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELHVFQUF1RSxFQUN2RTtJQUNJLE9BQU8sRUFBRSxHQUFHLEVBQUUsQ0FBQyw4QkFBOEI7Q0FDaEQsQ0FDSixDQUFDO0FBRUYsTUFBTSxVQUFVLDJCQUEyQixDQUN2QyxPQUE0QztJQUU1QyxPQUFPO1FBQ0gsT0FBTyxFQUFFLHNCQUFzQjtRQUMvQixRQUFRLGtDQUFNLDhCQUE4QixHQUFLLE9BQU8sQ0FBQztLQUM1RCxDQUFDO0FBQ04sQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7SW5qZWN0aW9uVG9rZW4sIFZhbHVlUHJvdmlkZXJ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQge1R1aVBkZlZpZXdlck9wdGlvbnN9IGZyb20gJy4vcGRmLXZpZXdlci1vcHRpb25zJztcblxudHlwZSBUdWlQZGZWaWV3ZXJEZWZhdWx0T3B0aW9ucyA9IE9taXQ8VHVpUGRmVmlld2VyT3B0aW9uczx1bmtub3duPiwgJ2RhdGEnPjtcblxuZXhwb3J0IGNvbnN0IFRVSV9QREZfVklFV0VSX0RFRkFVTFRfT1BUSU9OUyA9IHtsYWJlbDogYGAsIGFjdGlvbnM6IGBgfTtcblxuZXhwb3J0IGNvbnN0IFRVSV9QREZfVklFV0VSX09QVElPTlMgPSBuZXcgSW5qZWN0aW9uVG9rZW48VHVpUGRmVmlld2VyRGVmYXVsdE9wdGlvbnM+KFxuICAgIGBbVFVJX1BERl9WSUVXRVJfT1BUSU9OU106IERlZmF1bHQgcGFyYW1ldGVycyBmb3IgcGRmIHZpZXdlciBjb21wb25lbnRgLFxuICAgIHtcbiAgICAgICAgZmFjdG9yeTogKCkgPT4gVFVJX1BERl9WSUVXRVJfREVGQVVMVF9PUFRJT05TLFxuICAgIH0sXG4pO1xuXG5leHBvcnQgZnVuY3Rpb24gdHVpUGRmVmlld2VyT3B0aW9uc1Byb3ZpZGVyKFxuICAgIG9wdGlvbnM6IFBhcnRpYWw8VHVpUGRmVmlld2VyRGVmYXVsdE9wdGlvbnM+LFxuKTogVmFsdWVQcm92aWRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgcHJvdmlkZTogVFVJX1BERl9WSUVXRVJfT1BUSU9OUyxcbiAgICAgICAgdXNlVmFsdWU6IHsuLi5UVUlfUERGX1ZJRVdFUl9ERUZBVUxUX09QVElPTlMsIC4uLm9wdGlvbnN9LFxuICAgIH07XG59XG4iXX0=
|
|
@@ -3,6 +3,7 @@ export * from './push.directive';
|
|
|
3
3
|
export * from './push.module';
|
|
4
4
|
export * from './push.options';
|
|
5
5
|
export * from './push.service';
|
|
6
|
+
export * from './push.tokens';
|
|
6
7
|
export * from './push-alert.component';
|
|
7
8
|
export * from './push-alert.directive';
|
|
8
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wdXNoL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdXNoLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3B1c2guZGlyZWN0aXZlJztcbmV4cG9ydCAqIGZyb20gJy4vcHVzaC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9wdXNoLm9wdGlvbnMnO1xuZXhwb3J0ICogZnJvbSAnLi9wdXNoLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9wdXNoLnRva2Vucyc7XG5leHBvcnQgKiBmcm9tICcuL3B1c2gtYWxlcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcHVzaC1hbGVydC5kaXJlY3RpdmUnO1xuIl19
|
|
@@ -19,7 +19,7 @@ export class TuiPushComponent {
|
|
|
19
19
|
}
|
|
20
20
|
}
|
|
21
21
|
TuiPushComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiPushComponent, deps: [{ token: TUI_CLOSE_WORD }], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
-
TuiPushComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiPushComponent, selector: "tui-push", inputs: { heading: "heading", type: "type", timestamp: "timestamp" }, outputs: { close: "close" }, ngImport: i0, template: "<div class=\"t-image\"><ng-content select=\"img\"></ng-content></div>\n<button\n *ngIf=\"closeable\"\n tuiIconButton\n icon=\"tuiIconCloseLarge\"\n size=\"xs\"\n appearance=\"\"\n shape=\"rounded\"\n class=\"t-close\"\n [title]=\"closeWord$ | async\"\n (click)=\"close.emit()\"\n></button>\n<div class=\"t-top\">\n <span class=\"t-icon\"><ng-content select=\"tui-svg\"></ng-content></span>\n {{ type }}\n <span\n *ngIf=\"timestamp\"\n class=\"t-time\"\n [textContent]=\"timestamp | tuiFormatDate | async\"\n ></span>\n</div>\n<h3
|
|
22
|
+
TuiPushComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiPushComponent, selector: "tui-push", inputs: { heading: "heading", type: "type", timestamp: "timestamp" }, outputs: { close: "close" }, ngImport: i0, template: "<div class=\"t-image\"><ng-content select=\"img\"></ng-content></div>\n<button\n *ngIf=\"closeable\"\n tuiIconButton\n icon=\"tuiIconCloseLarge\"\n size=\"xs\"\n appearance=\"\"\n shape=\"rounded\"\n class=\"t-close\"\n [title]=\"closeWord$ | async\"\n (click)=\"close.emit()\"\n></button>\n<div class=\"t-top\">\n <span class=\"t-icon\"><ng-content select=\"tui-svg\"></ng-content></span>\n {{ type }}\n <span\n *ngIf=\"timestamp\"\n class=\"t-time\"\n [textContent]=\"timestamp | tuiFormatDate | async\"\n ></span>\n</div>\n<h3\n automation-id=\"tui-push__heading\"\n class=\"t-heading\"\n>\n {{ heading }}\n</h3>\n<div class=\"t-content\">\n <ng-content></ng-content>\n</div>\n<div class=\"t-actions\">\n <span class=\"t-button\"><ng-content select=\"[tuiButton]\"></ng-content></span>\n <span class=\"t-link\"><ng-content select=\"[tuiLink]\"></ng-content></span>\n</div>\n", styles: [":host{box-shadow:0 .25rem 1.5rem rgba(0,0,0,.12);position:relative;display:block;width:22.5rem;max-width:100%;box-sizing:border-box;padding:1.25rem 1.25rem .25rem;overflow:hidden;font:var(--tui-font-text-m);border-radius:var(--tui-radius-l);background:var(--tui-elevation-02)}.t-image{display:flex;flex-direction:column;max-height:10.625rem;overflow:hidden;margin:-1.25rem -1.25rem 1.25rem}.t-close{position:absolute;top:.75rem;right:.75rem;color:rgba(0,0,0,.54);background:rgba(242,242,242,.32);-webkit-backdrop-filter:blur(1rem);backdrop-filter:blur(1rem)}.t-top{display:flex;align-items:center;font:var(--tui-font-text-s);color:var(--tui-text-02)}.t-icon{height:1.25rem;margin-right:.5rem;transform:scale(.833);transform-origin:top left;color:var(--tui-link)}.t-time:before{content:\"\\2022\";display:inline-block;width:1rem;text-align:center}.t-heading{line-height:1.25rem;font-weight:bold;margin:.75rem 0 .25rem}.t-heading,.t-content{display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2;word-break:break-word;overflow:hidden}.t-actions{display:flex;align-items:center;font:var(--tui-font-text-s)}.t-button:not(:empty){margin:.75rem .75rem .75rem 0}.t-link{margin:.75rem 0}.t-link:empty{margin:.5rem}\n"], components: [{ type: i1.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], pipes: { "async": i2.AsyncPipe, "tuiFormatDate": i1.TuiFormatDatePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
23
23
|
__decorate([
|
|
24
24
|
tuiDefaultProp()
|
|
25
25
|
], TuiPushComponent.prototype, "heading", void 0);
|
|
@@ -49,4 +49,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
49
49
|
}], close: [{
|
|
50
50
|
type: Output
|
|
51
51
|
}] } });
|
|
52
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
52
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wdXNoL3B1c2guY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFDSCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULFlBQVksRUFDWixNQUFNLEVBQ04sS0FBSyxFQUNMLE1BQU0sR0FDVCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUMsY0FBYyxFQUFFLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUM1RCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sZ0JBQWdCLENBQUM7Ozs7O0FBUzlDLE1BQU0sT0FBTyxnQkFBZ0I7SUFnQnpCLFlBQTZDLFVBQThCO1FBQTlCLGVBQVUsR0FBVixVQUFVLENBQW9CO1FBYjNFLFlBQU8sR0FBRyxFQUFFLENBQUM7UUFJYixTQUFJLEdBQUcsRUFBRSxDQUFDO1FBSVYsY0FBUyxHQUFHLENBQUMsQ0FBQztRQUdMLFVBQUssR0FBRyxJQUFJLFlBQVksRUFBUSxDQUFDO0lBRW9DLENBQUM7SUFFL0UsSUFBSSxTQUFTO1FBQ1QsT0FBTyxhQUFhLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3JDLENBQUM7OzhHQXBCUSxnQkFBZ0Isa0JBZ0JMLGNBQWM7a0dBaEJ6QixnQkFBZ0IsbUpDbEI3Qiw2N0JBa0NBO0FEYkk7SUFEQyxjQUFjLEVBQUU7aURBQ0o7QUFJYjtJQURDLGNBQWMsRUFBRTs4Q0FDUDtBQUlWO0lBREMsY0FBYyxFQUFFO21EQUNIOzRGQVhMLGdCQUFnQjtrQkFONUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsVUFBVTtvQkFDcEIsV0FBVyxFQUFFLHNCQUFzQjtvQkFDbkMsU0FBUyxFQUFFLENBQUMsbUJBQW1CLENBQUM7b0JBQ2hDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs7MEJBaUJnQixNQUFNOzJCQUFDLGNBQWM7NENBYmxDLE9BQU87c0JBRk4sS0FBSztnQkFNTixJQUFJO3NCQUZILEtBQUs7Z0JBTU4sU0FBUztzQkFGUixLQUFLO2dCQUtHLEtBQUs7c0JBRGIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbmplY3QsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHVpRGVmYXVsdFByb3AsIHR1aUlzT2JzZXJ2ZWR9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHtUVUlfQ0xPU0VfV09SRH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IGB0dWktcHVzaGAsXG4gICAgdGVtcGxhdGVVcmw6IGAuL3B1c2gudGVtcGxhdGUuaHRtbGAsXG4gICAgc3R5bGVVcmxzOiBbYC4vcHVzaC5zdHlsZS5sZXNzYF0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aVB1c2hDb21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBoZWFkaW5nID0gYGA7XG5cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdHlwZSA9IGBgO1xuXG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIHRpbWVzdGFtcCA9IDA7XG5cbiAgICBAT3V0cHV0KClcbiAgICByZWFkb25seSBjbG9zZSA9IG5ldyBFdmVudEVtaXR0ZXI8dm9pZD4oKTtcblxuICAgIGNvbnN0cnVjdG9yKEBJbmplY3QoVFVJX0NMT1NFX1dPUkQpIHJlYWRvbmx5IGNsb3NlV29yZCQ6IE9ic2VydmFibGU8c3RyaW5nPikge31cblxuICAgIGdldCBjbG9zZWFibGUoKTogYm9vbGVhbiB7XG4gICAgICAgIHJldHVybiB0dWlJc09ic2VydmVkKHRoaXMuY2xvc2UpO1xuICAgIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJ0LWltYWdlXCI+PG5nLWNvbnRlbnQgc2VsZWN0PVwiaW1nXCI+PC9uZy1jb250ZW50PjwvZGl2PlxuPGJ1dHRvblxuICAgICpuZ0lmPVwiY2xvc2VhYmxlXCJcbiAgICB0dWlJY29uQnV0dG9uXG4gICAgaWNvbj1cInR1aUljb25DbG9zZUxhcmdlXCJcbiAgICBzaXplPVwieHNcIlxuICAgIGFwcGVhcmFuY2U9XCJcIlxuICAgIHNoYXBlPVwicm91bmRlZFwiXG4gICAgY2xhc3M9XCJ0LWNsb3NlXCJcbiAgICBbdGl0bGVdPVwiY2xvc2VXb3JkJCB8IGFzeW5jXCJcbiAgICAoY2xpY2spPVwiY2xvc2UuZW1pdCgpXCJcbj48L2J1dHRvbj5cbjxkaXYgY2xhc3M9XCJ0LXRvcFwiPlxuICAgIDxzcGFuIGNsYXNzPVwidC1pY29uXCI+PG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpLXN2Z1wiPjwvbmctY29udGVudD48L3NwYW4+XG4gICAge3sgdHlwZSB9fVxuICAgIDxzcGFuXG4gICAgICAgICpuZ0lmPVwidGltZXN0YW1wXCJcbiAgICAgICAgY2xhc3M9XCJ0LXRpbWVcIlxuICAgICAgICBbdGV4dENvbnRlbnRdPVwidGltZXN0YW1wIHwgdHVpRm9ybWF0RGF0ZSB8IGFzeW5jXCJcbiAgICA+PC9zcGFuPlxuPC9kaXY+XG48aDNcbiAgICBhdXRvbWF0aW9uLWlkPVwidHVpLXB1c2hfX2hlYWRpbmdcIlxuICAgIGNsYXNzPVwidC1oZWFkaW5nXCJcbj5cbiAgICB7eyBoZWFkaW5nIH19XG48L2gzPlxuPGRpdiBjbGFzcz1cInQtY29udGVudFwiPlxuICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbjwvZGl2PlxuPGRpdiBjbGFzcz1cInQtYWN0aW9uc1wiPlxuICAgIDxzcGFuIGNsYXNzPVwidC1idXR0b25cIj48bmctY29udGVudCBzZWxlY3Q9XCJbdHVpQnV0dG9uXVwiPjwvbmctY29udGVudD48L3NwYW4+XG4gICAgPHNwYW4gY2xhc3M9XCJ0LWxpbmtcIj48bmctY29udGVudCBzZWxlY3Q9XCJbdHVpTGlua11cIj48L25nLWNvbnRlbnQ+PC9zcGFuPlxuPC9kaXY+XG4iXX0=
|
|
@@ -1,10 +1,2 @@
|
|
|
1
|
-
export
|
|
2
|
-
|
|
3
|
-
type: ``,
|
|
4
|
-
timestamp: 0,
|
|
5
|
-
image: ``,
|
|
6
|
-
icon: ``,
|
|
7
|
-
iconColor: ``,
|
|
8
|
-
buttons: [],
|
|
9
|
-
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVUEsTUFBTSxDQUFDLE1BQU0sd0JBQXdCLEdBQW1CO0lBQ3BELE9BQU8sRUFBRSxFQUFFO0lBQ1gsSUFBSSxFQUFFLEVBQUU7SUFDUixTQUFTLEVBQUUsQ0FBQztJQUNaLEtBQUssRUFBRSxFQUFFO0lBQ1QsSUFBSSxFQUFFLEVBQUU7SUFDUixTQUFTLEVBQUUsRUFBRTtJQUNiLE9BQU8sRUFBRSxFQUFFO0NBQ2QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVHVpUHVzaE9wdGlvbnMge1xuICAgIHJlYWRvbmx5IGhlYWRpbmc6IHN0cmluZztcbiAgICByZWFkb25seSB0eXBlOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdGltZXN0YW1wOiBudW1iZXI7XG4gICAgcmVhZG9ubHkgaW1hZ2U6IHN0cmluZztcbiAgICByZWFkb25seSBpY29uOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgaWNvbkNvbG9yOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYnV0dG9uczogcmVhZG9ubHkgc3RyaW5nW107XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfUFVTSF9ERUZBVUxUX09QVElPTlM6IFR1aVB1c2hPcHRpb25zID0ge1xuICAgIGhlYWRpbmc6IGBgLFxuICAgIHR5cGU6IGBgLFxuICAgIHRpbWVzdGFtcDogMCxcbiAgICBpbWFnZTogYGAsXG4gICAgaWNvbjogYGAsXG4gICAgaWNvbkNvbG9yOiBgYCxcbiAgICBidXR0b25zOiBbXSxcbn07XG4iXX0=
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVHVpUHVzaE9wdGlvbnMge1xuICAgIHJlYWRvbmx5IGhlYWRpbmc6IHN0cmluZztcbiAgICByZWFkb25seSB0eXBlOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgdGltZXN0YW1wOiBudW1iZXI7XG4gICAgcmVhZG9ubHkgaW1hZ2U6IHN0cmluZztcbiAgICByZWFkb25seSBpY29uOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgaWNvbkNvbG9yOiBzdHJpbmc7XG4gICAgcmVhZG9ubHkgYnV0dG9uczogcmVhZG9ubHkgc3RyaW5nW107XG59XG4iXX0=
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { Injectable } from '@angular/core';
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
2
|
import { AbstractTuiDialogService } from '@taiga-ui/cdk';
|
|
3
3
|
import { PolymorpheusComponent } from '@tinkoff/ng-polymorpheus';
|
|
4
|
-
import {
|
|
4
|
+
import { TUI_PUSH_OPTIONS } from './push.tokens';
|
|
5
5
|
// TODO: find the best way for prevent cycle
|
|
6
6
|
// eslint-disable-next-line import/no-cycle
|
|
7
7
|
import { TuiPushAlertComponent } from './push-alert.component';
|
|
@@ -10,7 +10,7 @@ export class TuiPushService extends AbstractTuiDialogService {
|
|
|
10
10
|
constructor() {
|
|
11
11
|
super(...arguments);
|
|
12
12
|
this.component = new PolymorpheusComponent(TuiPushAlertComponent);
|
|
13
|
-
this.defaultOptions =
|
|
13
|
+
this.defaultOptions = inject(TUI_PUSH_OPTIONS);
|
|
14
14
|
}
|
|
15
15
|
open(content, options = {}) {
|
|
16
16
|
return super.open(content, options);
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
22
22
|
type: Injectable,
|
|
23
23
|
args: [{ providedIn: `root` }]
|
|
24
24
|
}] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMva2l0L2NvbXBvbmVudHMvcHVzaC9wdXNoLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDakQsT0FBTyxFQUFDLHdCQUF3QixFQUF1QixNQUFNLGVBQWUsQ0FBQztBQUM3RSxPQUFPLEVBQUMscUJBQXFCLEVBQXNCLE1BQU0sMEJBQTBCLENBQUM7QUFJcEYsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQy9DLDRDQUE0QztBQUM1QywyQ0FBMkM7QUFDM0MsT0FBTyxFQUFDLHFCQUFxQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7O0FBRzdELE1BQU0sT0FBTyxjQUFlLFNBQVEsd0JBQWdEO0lBRHBGOztRQUV1QixjQUFTLEdBQUcsSUFBSSxxQkFBcUIsQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQzdELG1CQUFjLEdBQUcsTUFBTSxDQUFDLGdCQUFnQixDQUFDLENBQUM7S0FRaEU7SUFOWSxJQUFJLENBQ1QsT0FBMkUsRUFDM0UsVUFBbUMsRUFBRTtRQUVyQyxPQUFPLEtBQUssQ0FBQyxJQUFJLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3hDLENBQUM7OzRHQVRRLGNBQWM7Z0hBQWQsY0FBYyxjQURGLE1BQU07NEZBQ2xCLGNBQWM7a0JBRDFCLFVBQVU7bUJBQUMsRUFBQyxVQUFVLEVBQUUsTUFBTSxFQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtpbmplY3QsIEluamVjdGFibGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtBYnN0cmFjdFR1aURpYWxvZ1NlcnZpY2UsIFR1aUJhc2VEaWFsb2dDb250ZXh0fSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29tcG9uZW50LCBQb2x5bW9ycGhldXNDb250ZW50fSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHtUdWlQdXNoT3B0aW9uc30gZnJvbSAnLi9wdXNoLm9wdGlvbnMnO1xuaW1wb3J0IHtUVUlfUFVTSF9PUFRJT05TfSBmcm9tICcuL3B1c2gudG9rZW5zJztcbi8vIFRPRE86IGZpbmQgdGhlIGJlc3Qgd2F5IGZvciBwcmV2ZW50IGN5Y2xlXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L25vLWN5Y2xlXG5pbXBvcnQge1R1aVB1c2hBbGVydENvbXBvbmVudH0gZnJvbSAnLi9wdXNoLWFsZXJ0LmNvbXBvbmVudCc7XG5cbkBJbmplY3RhYmxlKHtwcm92aWRlZEluOiBgcm9vdGB9KVxuZXhwb3J0IGNsYXNzIFR1aVB1c2hTZXJ2aWNlIGV4dGVuZHMgQWJzdHJhY3RUdWlEaWFsb2dTZXJ2aWNlPFR1aVB1c2hPcHRpb25zLCBzdHJpbmc+IHtcbiAgICBwcm90ZWN0ZWQgcmVhZG9ubHkgY29tcG9uZW50ID0gbmV3IFBvbHltb3JwaGV1c0NvbXBvbmVudChUdWlQdXNoQWxlcnRDb21wb25lbnQpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSBkZWZhdWx0T3B0aW9ucyA9IGluamVjdChUVUlfUFVTSF9PUFRJT05TKTtcblxuICAgIG92ZXJyaWRlIG9wZW4oXG4gICAgICAgIGNvbnRlbnQ6IFBvbHltb3JwaGV1c0NvbnRlbnQ8VHVpQmFzZURpYWxvZ0NvbnRleHQ8c3RyaW5nPiAmIFR1aVB1c2hPcHRpb25zPixcbiAgICAgICAgb3B0aW9uczogUGFydGlhbDxUdWlQdXNoT3B0aW9ucz4gPSB7fSxcbiAgICApOiBPYnNlcnZhYmxlPHN0cmluZz4ge1xuICAgICAgICByZXR1cm4gc3VwZXIub3Blbihjb250ZW50LCBvcHRpb25zKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { InjectionToken } from '@angular/core';
|
|
2
|
+
export const TUI_PUSH_DEFAULT_OPTIONS = {
|
|
3
|
+
heading: ``,
|
|
4
|
+
type: ``,
|
|
5
|
+
timestamp: 0,
|
|
6
|
+
image: ``,
|
|
7
|
+
icon: ``,
|
|
8
|
+
iconColor: ``,
|
|
9
|
+
buttons: [],
|
|
10
|
+
};
|
|
11
|
+
export const TUI_PUSH_OPTIONS = new InjectionToken(`[TUI_PUSH_OPTIONS]: Default parameters for push component`, {
|
|
12
|
+
factory: () => TUI_PUSH_DEFAULT_OPTIONS,
|
|
13
|
+
});
|
|
14
|
+
export function tuiPushOptionsProvider(options) {
|
|
15
|
+
return {
|
|
16
|
+
provide: TUI_PUSH_OPTIONS,
|
|
17
|
+
useValue: Object.assign(Object.assign({}, TUI_PUSH_DEFAULT_OPTIONS), options),
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVzaC50b2tlbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9wdXNoL3B1c2gudG9rZW5zLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxjQUFjLEVBQWdCLE1BQU0sZUFBZSxDQUFDO0FBSTVELE1BQU0sQ0FBQyxNQUFNLHdCQUF3QixHQUFtQjtJQUNwRCxPQUFPLEVBQUUsRUFBRTtJQUNYLElBQUksRUFBRSxFQUFFO0lBQ1IsU0FBUyxFQUFFLENBQUM7SUFDWixLQUFLLEVBQUUsRUFBRTtJQUNULElBQUksRUFBRSxFQUFFO0lBQ1IsU0FBUyxFQUFFLEVBQUU7SUFDYixPQUFPLEVBQUUsRUFBRTtDQUNkLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLGNBQWMsQ0FDOUMsMkRBQTJELEVBQzNEO0lBQ0ksT0FBTyxFQUFFLEdBQUcsRUFBRSxDQUFDLHdCQUF3QjtDQUMxQyxDQUNKLENBQUM7QUFFRixNQUFNLFVBQVUsc0JBQXNCLENBQUMsT0FBZ0M7SUFDbkUsT0FBTztRQUNILE9BQU8sRUFBRSxnQkFBZ0I7UUFDekIsUUFBUSxrQ0FBTSx3QkFBd0IsR0FBSyxPQUFPLENBQUM7S0FDdEQsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VuLCBWYWx1ZVByb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtUdWlQdXNoT3B0aW9uc30gZnJvbSAnLi9wdXNoLm9wdGlvbnMnO1xuXG5leHBvcnQgY29uc3QgVFVJX1BVU0hfREVGQVVMVF9PUFRJT05TOiBUdWlQdXNoT3B0aW9ucyA9IHtcbiAgICBoZWFkaW5nOiBgYCxcbiAgICB0eXBlOiBgYCxcbiAgICB0aW1lc3RhbXA6IDAsXG4gICAgaW1hZ2U6IGBgLFxuICAgIGljb246IGBgLFxuICAgIGljb25Db2xvcjogYGAsXG4gICAgYnV0dG9uczogW10sXG59O1xuXG5leHBvcnQgY29uc3QgVFVJX1BVU0hfT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxUdWlQdXNoT3B0aW9ucz4oXG4gICAgYFtUVUlfUFVTSF9PUFRJT05TXTogRGVmYXVsdCBwYXJhbWV0ZXJzIGZvciBwdXNoIGNvbXBvbmVudGAsXG4gICAge1xuICAgICAgICBmYWN0b3J5OiAoKSA9PiBUVUlfUFVTSF9ERUZBVUxUX09QVElPTlMsXG4gICAgfSxcbik7XG5cbmV4cG9ydCBmdW5jdGlvbiB0dWlQdXNoT3B0aW9uc1Byb3ZpZGVyKG9wdGlvbnM6IFBhcnRpYWw8VHVpUHVzaE9wdGlvbnM+KTogVmFsdWVQcm92aWRlciB7XG4gICAgcmV0dXJuIHtcbiAgICAgICAgcHJvdmlkZTogVFVJX1BVU0hfT1BUSU9OUyxcbiAgICAgICAgdXNlVmFsdWU6IHsuLi5UVUlfUFVTSF9ERUZBVUxUX09QVElPTlMsIC4uLm9wdGlvbnN9LFxuICAgIH07XG59XG4iXX0=
|
|
@@ -1,5 +1,8 @@
|
|
|
1
|
+
export * from './native-select/native-select';
|
|
2
|
+
export * from './native-select/native-select.component';
|
|
3
|
+
export * from './native-select/native-select-group.component';
|
|
1
4
|
export * from './select.component';
|
|
2
5
|
export * from './select.directive';
|
|
3
6
|
export * from './select.module';
|
|
4
7
|
export * from './select-options';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9zZWxlY3QvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlDQUF5QyxDQUFDO0FBQ3hELGNBQWMsK0NBQStDLENBQUM7QUFDOUQsY0FBYyxvQkFBb0IsQ0FBQztBQUNuQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxrQkFBa0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbmF0aXZlLXNlbGVjdC9uYXRpdmUtc2VsZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vbmF0aXZlLXNlbGVjdC9uYXRpdmUtc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25hdGl2ZS1zZWxlY3QvbmF0aXZlLXNlbGVjdC1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3Qtb3B0aW9ucyc7XG4iXX0=
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import { TuiDataListDirective } from '@taiga-ui/core';
|
|
3
|
+
import { AbstractTuiNativeSelect } from './native-select';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@taiga-ui/kit/components/data-list-wrapper";
|
|
6
|
+
import * as i2 from "@taiga-ui/core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
export class TuiNativeSelectGroupComponent extends AbstractTuiNativeSelect {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.items = [];
|
|
12
|
+
this.labels = [];
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
TuiNativeSelectGroupComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiNativeSelectGroupComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
16
|
+
TuiNativeSelectGroupComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiNativeSelectGroupComponent, selector: "select[tuiSelect][labels]", inputs: { items: "items", labels: "labels" }, host: { listeners: { "change": "host.onValueChange($event.target.value)" }, properties: { "attr.aria-invalid": "host.invalid", "disabled": "host.disabled", "tabIndex": "host.focusable ? 0 : -1", "readOnly": "host.readOnly", "value": "host.value" } }, providers: [
|
|
17
|
+
{
|
|
18
|
+
provide: TuiDataListDirective,
|
|
19
|
+
deps: [TuiNativeSelectGroupComponent],
|
|
20
|
+
useExisting: TuiNativeSelectGroupComponent,
|
|
21
|
+
},
|
|
22
|
+
{
|
|
23
|
+
provide: TemplateRef,
|
|
24
|
+
deps: [TuiNativeSelectGroupComponent],
|
|
25
|
+
useFactory: ({ datalist }) => datalist,
|
|
26
|
+
},
|
|
27
|
+
{
|
|
28
|
+
provide: AbstractTuiNativeSelect,
|
|
29
|
+
useExisting: TuiNativeSelectGroupComponent,
|
|
30
|
+
},
|
|
31
|
+
], usesInheritance: true, ngImport: i0, template: "<tui-data-list-wrapper\n *tuiDataList\n [items]=\"items\"\n [labels]=\"labels\"\n></tui-data-list-wrapper>\n<optgroup\n *ngFor=\"let group of items; let index = index\"\n [label]=\"labels[index]\"\n>\n <option\n *ngFor=\"let option of group\"\n [value]=\"option\"\n >\n {{ option }}\n </option>\n</optgroup>\n", styles: [":host{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0}\n"], components: [{ type: i1.TuiDataListGroupWrapperComponent, selector: "tui-data-list-wrapper[labels]", inputs: ["items", "labels"] }], directives: [{ type: i2.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiNativeSelectGroupComponent, decorators: [{
|
|
33
|
+
type: Component,
|
|
34
|
+
args: [{
|
|
35
|
+
selector: `select[tuiSelect][labels]`,
|
|
36
|
+
templateUrl: `./native-select-group.template.html`,
|
|
37
|
+
providers: [
|
|
38
|
+
{
|
|
39
|
+
provide: TuiDataListDirective,
|
|
40
|
+
deps: [TuiNativeSelectGroupComponent],
|
|
41
|
+
useExisting: TuiNativeSelectGroupComponent,
|
|
42
|
+
},
|
|
43
|
+
{
|
|
44
|
+
provide: TemplateRef,
|
|
45
|
+
deps: [TuiNativeSelectGroupComponent],
|
|
46
|
+
useFactory: ({ datalist }) => datalist,
|
|
47
|
+
},
|
|
48
|
+
{
|
|
49
|
+
provide: AbstractTuiNativeSelect,
|
|
50
|
+
useExisting: TuiNativeSelectGroupComponent,
|
|
51
|
+
},
|
|
52
|
+
],
|
|
53
|
+
host: {
|
|
54
|
+
'[attr.aria-invalid]': `host.invalid`,
|
|
55
|
+
'[disabled]': `host.disabled`,
|
|
56
|
+
'[tabIndex]': `host.focusable ? 0 : -1`,
|
|
57
|
+
'[readOnly]': `host.readOnly`,
|
|
58
|
+
'[value]': `host.value`,
|
|
59
|
+
'(change)': `host.onValueChange($event.target.value)`,
|
|
60
|
+
},
|
|
61
|
+
styleUrls: [`./native-select.style.less`],
|
|
62
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
63
|
+
}]
|
|
64
|
+
}], propDecorators: { items: [{
|
|
65
|
+
type: Input
|
|
66
|
+
}], labels: [{
|
|
67
|
+
type: Input
|
|
68
|
+
}] } });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlLXNlbGVjdC1ncm91cC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9zZWxlY3QvbmF0aXZlLXNlbGVjdC9uYXRpdmUtc2VsZWN0LWdyb3VwLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3NlbGVjdC9uYXRpdmUtc2VsZWN0L25hdGl2ZS1zZWxlY3QtZ3JvdXAudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDckYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFcEQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0saUJBQWlCLENBQUM7Ozs7O0FBZ0N4RCxNQUFNLE9BQU8sNkJBQThCLFNBQVEsdUJBQXVCO0lBOUIxRTs7UUFnQ0ksVUFBSyxHQUErQixFQUFFLENBQUM7UUFHdkMsV0FBTSxHQUFzQixFQUFFLENBQUM7S0FDbEM7OzJIQU5ZLDZCQUE2QjsrR0FBN0IsNkJBQTZCLDZWQTNCM0I7UUFDUDtZQUNJLE9BQU8sRUFBRSxvQkFBb0I7WUFDN0IsSUFBSSxFQUFFLENBQUMsNkJBQTZCLENBQUM7WUFDckMsV0FBVyxFQUFFLDZCQUE2QjtTQUM3QztRQUNEO1lBQ0ksT0FBTyxFQUFFLFdBQVc7WUFDcEIsSUFBSSxFQUFFLENBQUMsNkJBQTZCLENBQUM7WUFDckMsVUFBVSxFQUFFLENBQUMsRUFBQyxRQUFRLEVBQWdDLEVBQUUsRUFBRSxDQUFDLFFBQVE7U0FDdEU7UUFDRDtZQUNJLE9BQU8sRUFBRSx1QkFBdUI7WUFDaEMsV0FBVyxFQUFFLDZCQUE2QjtTQUM3QztLQUNKLGlEQ3ZCTCxvV0FnQkE7NEZEbUJhLDZCQUE2QjtrQkE5QnpDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsV0FBVyxFQUFFLHFDQUFxQztvQkFDbEQsU0FBUyxFQUFFO3dCQUNQOzRCQUNJLE9BQU8sRUFBRSxvQkFBb0I7NEJBQzdCLElBQUksRUFBRSwrQkFBK0I7NEJBQ3JDLFdBQVcsK0JBQStCO3lCQUM3Qzt3QkFDRDs0QkFDSSxPQUFPLEVBQUUsV0FBVzs0QkFDcEIsSUFBSSxFQUFFLCtCQUErQjs0QkFDckMsVUFBVSxFQUFFLENBQUMsRUFBQyxRQUFRLEVBQWdDLEVBQUUsRUFBRSxDQUFDLFFBQVE7eUJBQ3RFO3dCQUNEOzRCQUNJLE9BQU8sRUFBRSx1QkFBdUI7NEJBQ2hDLFdBQVcsK0JBQStCO3lCQUM3QztxQkFDSjtvQkFDRCxJQUFJLEVBQUU7d0JBQ0YscUJBQXFCLEVBQUUsY0FBYzt3QkFDckMsWUFBWSxFQUFFLGVBQWU7d0JBQzdCLFlBQVksRUFBRSx5QkFBeUI7d0JBQ3ZDLFlBQVksRUFBRSxlQUFlO3dCQUM3QixTQUFTLEVBQUUsWUFBWTt3QkFDdkIsVUFBVSxFQUFFLHlDQUF5QztxQkFDeEQ7b0JBQ0QsU0FBUyxFQUFFLENBQUMsNEJBQTRCLENBQUM7b0JBQ3pDLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs4QkFHRyxLQUFLO3NCQURKLEtBQUs7Z0JBSU4sTUFBTTtzQkFETCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgVGVtcGxhdGVSZWZ9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlEYXRhTGlzdERpcmVjdGl2ZX0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5pbXBvcnQge0Fic3RyYWN0VHVpTmF0aXZlU2VsZWN0fSBmcm9tICcuL25hdGl2ZS1zZWxlY3QnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogYHNlbGVjdFt0dWlTZWxlY3RdW2xhYmVsc11gLFxuICAgIHRlbXBsYXRlVXJsOiBgLi9uYXRpdmUtc2VsZWN0LWdyb3VwLnRlbXBsYXRlLmh0bWxgLFxuICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7XG4gICAgICAgICAgICBwcm92aWRlOiBUdWlEYXRhTGlzdERpcmVjdGl2ZSxcbiAgICAgICAgICAgIGRlcHM6IFtUdWlOYXRpdmVTZWxlY3RHcm91cENvbXBvbmVudF0sXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogVHVpTmF0aXZlU2VsZWN0R3JvdXBDb21wb25lbnQsXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IFRlbXBsYXRlUmVmLFxuICAgICAgICAgICAgZGVwczogW1R1aU5hdGl2ZVNlbGVjdEdyb3VwQ29tcG9uZW50XSxcbiAgICAgICAgICAgIHVzZUZhY3Rvcnk6ICh7ZGF0YWxpc3R9OiBUdWlOYXRpdmVTZWxlY3RHcm91cENvbXBvbmVudCkgPT4gZGF0YWxpc3QsXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IEFic3RyYWN0VHVpTmF0aXZlU2VsZWN0LFxuICAgICAgICAgICAgdXNlRXhpc3Rpbmc6IFR1aU5hdGl2ZVNlbGVjdEdyb3VwQ29tcG9uZW50LFxuICAgICAgICB9LFxuICAgIF0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuYXJpYS1pbnZhbGlkXSc6IGBob3N0LmludmFsaWRgLFxuICAgICAgICAnW2Rpc2FibGVkXSc6IGBob3N0LmRpc2FibGVkYCxcbiAgICAgICAgJ1t0YWJJbmRleF0nOiBgaG9zdC5mb2N1c2FibGUgPyAwIDogLTFgLFxuICAgICAgICAnW3JlYWRPbmx5XSc6IGBob3N0LnJlYWRPbmx5YCxcbiAgICAgICAgJ1t2YWx1ZV0nOiBgaG9zdC52YWx1ZWAsXG4gICAgICAgICcoY2hhbmdlKSc6IGBob3N0Lm9uVmFsdWVDaGFuZ2UoJGV2ZW50LnRhcmdldC52YWx1ZSlgLFxuICAgIH0sXG4gICAgc3R5bGVVcmxzOiBbYC4vbmF0aXZlLXNlbGVjdC5zdHlsZS5sZXNzYF0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aU5hdGl2ZVNlbGVjdEdyb3VwQ29tcG9uZW50IGV4dGVuZHMgQWJzdHJhY3RUdWlOYXRpdmVTZWxlY3Qge1xuICAgIEBJbnB1dCgpXG4gICAgaXRlbXM6IHJlYWRvbmx5IHN0cmluZ1tdW10gfCBudWxsID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIGxhYmVsczogcmVhZG9ubHkgc3RyaW5nW10gPSBbXTtcbn1cbiIsIjx0dWktZGF0YS1saXN0LXdyYXBwZXJcbiAgICAqdHVpRGF0YUxpc3RcbiAgICBbaXRlbXNdPVwiaXRlbXNcIlxuICAgIFtsYWJlbHNdPVwibGFiZWxzXCJcbj48L3R1aS1kYXRhLWxpc3Qtd3JhcHBlcj5cbjxvcHRncm91cFxuICAgICpuZ0Zvcj1cImxldCBncm91cCBvZiBpdGVtczsgbGV0IGluZGV4ID0gaW5kZXhcIlxuICAgIFtsYWJlbF09XCJsYWJlbHNbaW5kZXhdXCJcbj5cbiAgICA8b3B0aW9uXG4gICAgICAgICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgZ3JvdXBcIlxuICAgICAgICBbdmFsdWVdPVwib3B0aW9uXCJcbiAgICA+XG4gICAgICAgIHt7IG9wdGlvbiB9fVxuICAgIDwvb3B0aW9uPlxuPC9vcHRncm91cD5cbiJdfQ==
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, Input, TemplateRef } from '@angular/core';
|
|
2
|
+
import { TuiDataListDirective } from '@taiga-ui/core';
|
|
3
|
+
import { AbstractTuiNativeSelect } from './native-select';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@taiga-ui/kit/components/data-list-wrapper";
|
|
6
|
+
import * as i2 from "@taiga-ui/core";
|
|
7
|
+
import * as i3 from "@angular/common";
|
|
8
|
+
export class TuiNativeSelectComponent extends AbstractTuiNativeSelect {
|
|
9
|
+
constructor() {
|
|
10
|
+
super(...arguments);
|
|
11
|
+
this.items = [];
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
TuiNativeSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiNativeSelectComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
15
|
+
TuiNativeSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiNativeSelectComponent, selector: "select[tuiSelect]:not([labels])", inputs: { items: "items" }, host: { listeners: { "change": "host.onValueChange($event.target.value)" }, properties: { "attr.aria-invalid": "host.invalid", "disabled": "host.disabled", "tabIndex": "host.focusable ? 0 : -1", "readOnly": "host.readOnly", "value": "host.value" } }, providers: [
|
|
16
|
+
{
|
|
17
|
+
provide: TuiDataListDirective,
|
|
18
|
+
deps: [TuiNativeSelectComponent],
|
|
19
|
+
useExisting: TuiNativeSelectComponent,
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
provide: TemplateRef,
|
|
23
|
+
deps: [TuiNativeSelectComponent],
|
|
24
|
+
useFactory: ({ datalist }) => datalist,
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
provide: AbstractTuiNativeSelect,
|
|
28
|
+
useExisting: TuiNativeSelectComponent,
|
|
29
|
+
},
|
|
30
|
+
], usesInheritance: true, ngImport: i0, template: "<tui-data-list-wrapper\n *tuiDataList\n [items]=\"items\"\n></tui-data-list-wrapper>\n<option\n *ngFor=\"let option of items\"\n [value]=\"option\"\n>\n {{ option }}\n</option>\n", styles: [":host{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0}\n"], components: [{ type: i1.TuiDataListWrapperComponent, selector: "tui-data-list-wrapper:not([labels])", inputs: ["items"] }], directives: [{ type: i2.TuiDataListDirective, selector: "ng-template[tuiDataList]" }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
31
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiNativeSelectComponent, decorators: [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{
|
|
34
|
+
selector: `select[tuiSelect]:not([labels])`,
|
|
35
|
+
templateUrl: `./native-select.template.html`,
|
|
36
|
+
providers: [
|
|
37
|
+
{
|
|
38
|
+
provide: TuiDataListDirective,
|
|
39
|
+
deps: [TuiNativeSelectComponent],
|
|
40
|
+
useExisting: TuiNativeSelectComponent,
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
provide: TemplateRef,
|
|
44
|
+
deps: [TuiNativeSelectComponent],
|
|
45
|
+
useFactory: ({ datalist }) => datalist,
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
provide: AbstractTuiNativeSelect,
|
|
49
|
+
useExisting: TuiNativeSelectComponent,
|
|
50
|
+
},
|
|
51
|
+
],
|
|
52
|
+
host: {
|
|
53
|
+
'[attr.aria-invalid]': `host.invalid`,
|
|
54
|
+
'[disabled]': `host.disabled`,
|
|
55
|
+
'[tabIndex]': `host.focusable ? 0 : -1`,
|
|
56
|
+
'[readOnly]': `host.readOnly`,
|
|
57
|
+
'[value]': `host.value`,
|
|
58
|
+
'(change)': `host.onValueChange($event.target.value)`,
|
|
59
|
+
},
|
|
60
|
+
styleUrls: [`./native-select.style.less`],
|
|
61
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
62
|
+
}]
|
|
63
|
+
}], propDecorators: { items: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}] } });
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlLXNlbGVjdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9raXQvY29tcG9uZW50cy9zZWxlY3QvbmF0aXZlLXNlbGVjdC9uYXRpdmUtc2VsZWN0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3NlbGVjdC9uYXRpdmUtc2VsZWN0L25hdGl2ZS1zZWxlY3QudGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDckYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFcEQsT0FBTyxFQUFDLHVCQUF1QixFQUFDLE1BQU0saUJBQWlCLENBQUM7Ozs7O0FBZ0N4RCxNQUFNLE9BQU8sd0JBQXlCLFNBQVEsdUJBQXVCO0lBOUJyRTs7UUFnQ0ksVUFBSyxHQUE2QixFQUFFLENBQUM7S0FDeEM7O3NIQUhZLHdCQUF3QjswR0FBeEIsd0JBQXdCLGlWQTNCdEI7UUFDUDtZQUNJLE9BQU8sRUFBRSxvQkFBb0I7WUFDN0IsSUFBSSxFQUFFLENBQUMsd0JBQXdCLENBQUM7WUFDaEMsV0FBVyxFQUFFLHdCQUF3QjtTQUN4QztRQUNEO1lBQ0ksT0FBTyxFQUFFLFdBQVc7WUFDcEIsSUFBSSxFQUFFLENBQUMsd0JBQXdCLENBQUM7WUFDaEMsVUFBVSxFQUFFLENBQUMsRUFBQyxRQUFRLEVBQTJCLEVBQUUsRUFBRSxDQUFDLFFBQVE7U0FDakU7UUFDRDtZQUNJLE9BQU8sRUFBRSx1QkFBdUI7WUFDaEMsV0FBVyxFQUFFLHdCQUF3QjtTQUN4QztLQUNKLGlEQ3ZCTCxtTUFVQTs0RkR5QmEsd0JBQXdCO2tCQTlCcEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsaUNBQWlDO29CQUMzQyxXQUFXLEVBQUUsK0JBQStCO29CQUM1QyxTQUFTLEVBQUU7d0JBQ1A7NEJBQ0ksT0FBTyxFQUFFLG9CQUFvQjs0QkFDN0IsSUFBSSxFQUFFLDBCQUEwQjs0QkFDaEMsV0FBVywwQkFBMEI7eUJBQ3hDO3dCQUNEOzRCQUNJLE9BQU8sRUFBRSxXQUFXOzRCQUNwQixJQUFJLEVBQUUsMEJBQTBCOzRCQUNoQyxVQUFVLEVBQUUsQ0FBQyxFQUFDLFFBQVEsRUFBMkIsRUFBRSxFQUFFLENBQUMsUUFBUTt5QkFDakU7d0JBQ0Q7NEJBQ0ksT0FBTyxFQUFFLHVCQUF1Qjs0QkFDaEMsV0FBVywwQkFBMEI7eUJBQ3hDO3FCQUNKO29CQUNELElBQUksRUFBRTt3QkFDRixxQkFBcUIsRUFBRSxjQUFjO3dCQUNyQyxZQUFZLEVBQUUsZUFBZTt3QkFDN0IsWUFBWSxFQUFFLHlCQUF5Qjt3QkFDdkMsWUFBWSxFQUFFLGVBQWU7d0JBQzdCLFNBQVMsRUFBRSxZQUFZO3dCQUN2QixVQUFVLEVBQUUseUNBQXlDO3FCQUN4RDtvQkFDRCxTQUFTLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztvQkFDekMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzhCQUdHLEtBQUs7c0JBREosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIFRlbXBsYXRlUmVmfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VHVpRGF0YUxpc3REaXJlY3RpdmV9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcblxuaW1wb3J0IHtBYnN0cmFjdFR1aU5hdGl2ZVNlbGVjdH0gZnJvbSAnLi9uYXRpdmUtc2VsZWN0JztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IGBzZWxlY3RbdHVpU2VsZWN0XTpub3QoW2xhYmVsc10pYCxcbiAgICB0ZW1wbGF0ZVVybDogYC4vbmF0aXZlLXNlbGVjdC50ZW1wbGF0ZS5odG1sYCxcbiAgICBwcm92aWRlcnM6IFtcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogVHVpRGF0YUxpc3REaXJlY3RpdmUsXG4gICAgICAgICAgICBkZXBzOiBbVHVpTmF0aXZlU2VsZWN0Q29tcG9uZW50XSxcbiAgICAgICAgICAgIHVzZUV4aXN0aW5nOiBUdWlOYXRpdmVTZWxlY3RDb21wb25lbnQsXG4gICAgICAgIH0sXG4gICAgICAgIHtcbiAgICAgICAgICAgIHByb3ZpZGU6IFRlbXBsYXRlUmVmLFxuICAgICAgICAgICAgZGVwczogW1R1aU5hdGl2ZVNlbGVjdENvbXBvbmVudF0sXG4gICAgICAgICAgICB1c2VGYWN0b3J5OiAoe2RhdGFsaXN0fTogVHVpTmF0aXZlU2VsZWN0Q29tcG9uZW50KSA9PiBkYXRhbGlzdCxcbiAgICAgICAgfSxcbiAgICAgICAge1xuICAgICAgICAgICAgcHJvdmlkZTogQWJzdHJhY3RUdWlOYXRpdmVTZWxlY3QsXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogVHVpTmF0aXZlU2VsZWN0Q29tcG9uZW50LFxuICAgICAgICB9LFxuICAgIF0sXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuYXJpYS1pbnZhbGlkXSc6IGBob3N0LmludmFsaWRgLFxuICAgICAgICAnW2Rpc2FibGVkXSc6IGBob3N0LmRpc2FibGVkYCxcbiAgICAgICAgJ1t0YWJJbmRleF0nOiBgaG9zdC5mb2N1c2FibGUgPyAwIDogLTFgLFxuICAgICAgICAnW3JlYWRPbmx5XSc6IGBob3N0LnJlYWRPbmx5YCxcbiAgICAgICAgJ1t2YWx1ZV0nOiBgaG9zdC52YWx1ZWAsXG4gICAgICAgICcoY2hhbmdlKSc6IGBob3N0Lm9uVmFsdWVDaGFuZ2UoJGV2ZW50LnRhcmdldC52YWx1ZSlgLFxuICAgIH0sXG4gICAgc3R5bGVVcmxzOiBbYC4vbmF0aXZlLXNlbGVjdC5zdHlsZS5sZXNzYF0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aU5hdGl2ZVNlbGVjdENvbXBvbmVudCBleHRlbmRzIEFic3RyYWN0VHVpTmF0aXZlU2VsZWN0IHtcbiAgICBASW5wdXQoKVxuICAgIGl0ZW1zOiByZWFkb25seSBzdHJpbmdbXSB8IG51bGwgPSBbXTtcbn1cbiIsIjx0dWktZGF0YS1saXN0LXdyYXBwZXJcbiAgICAqdHVpRGF0YUxpc3RcbiAgICBbaXRlbXNdPVwiaXRlbXNcIlxuPjwvdHVpLWRhdGEtbGlzdC13cmFwcGVyPlxuPG9wdGlvblxuICAgICpuZ0Zvcj1cImxldCBvcHRpb24gb2YgaXRlbXNcIlxuICAgIFt2YWx1ZV09XCJvcHRpb25cIlxuPlxuICAgIHt7IG9wdGlvbiB9fVxuPC9vcHRpb24+XG4iXX0=
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { Directive, ElementRef, HostBinding, Inject, TemplateRef, ViewChild, } from '@angular/core';
|
|
2
|
+
import { TuiIdService } from '@taiga-ui/cdk';
|
|
3
|
+
import { TUI_TEXTFIELD_HOST, TuiDataListDirective } from '@taiga-ui/core';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@taiga-ui/cdk";
|
|
6
|
+
export class AbstractTuiNativeSelect {
|
|
7
|
+
constructor(host, elementRef, idService) {
|
|
8
|
+
this.host = host;
|
|
9
|
+
this.elementRef = elementRef;
|
|
10
|
+
this.idService = idService;
|
|
11
|
+
this.datalist = null;
|
|
12
|
+
this.host.process(this.elementRef.nativeElement);
|
|
13
|
+
}
|
|
14
|
+
get id() {
|
|
15
|
+
return this.elementRef.nativeElement.id || this.idService.generate();
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
AbstractTuiNativeSelect.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: AbstractTuiNativeSelect, deps: [{ token: TUI_TEXTFIELD_HOST }, { token: ElementRef }, { token: TuiIdService }], target: i0.ɵɵFactoryTarget.Directive });
|
|
19
|
+
AbstractTuiNativeSelect.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "12.2.16", type: AbstractTuiNativeSelect, host: { properties: { "id": "this.id" } }, viewQueries: [{ propertyName: "datalist", first: true, predicate: TuiDataListDirective, descendants: true, read: TemplateRef, static: true }], ngImport: i0 });
|
|
20
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: AbstractTuiNativeSelect, decorators: [{
|
|
21
|
+
type: Directive
|
|
22
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
23
|
+
type: Inject,
|
|
24
|
+
args: [TUI_TEXTFIELD_HOST]
|
|
25
|
+
}] }, { type: i0.ElementRef, decorators: [{
|
|
26
|
+
type: Inject,
|
|
27
|
+
args: [ElementRef]
|
|
28
|
+
}] }, { type: i1.TuiIdService, decorators: [{
|
|
29
|
+
type: Inject,
|
|
30
|
+
args: [TuiIdService]
|
|
31
|
+
}] }]; }, propDecorators: { datalist: [{
|
|
32
|
+
type: ViewChild,
|
|
33
|
+
args: [TuiDataListDirective, { read: TemplateRef, static: true }]
|
|
34
|
+
}], id: [{
|
|
35
|
+
type: HostBinding,
|
|
36
|
+
args: [`id`]
|
|
37
|
+
}] } });
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmF0aXZlLXNlbGVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tpdC9jb21wb25lbnRzL3NlbGVjdC9uYXRpdmUtc2VsZWN0L25hdGl2ZS1zZWxlY3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILFNBQVMsRUFDVCxVQUFVLEVBQ1YsV0FBVyxFQUNYLE1BQU0sRUFDTixXQUFXLEVBQ1gsU0FBUyxHQUNaLE1BQU0sZUFBZSxDQUFDO0FBQ3ZCLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFDLGtCQUFrQixFQUFFLG9CQUFvQixFQUFtQixNQUFNLGdCQUFnQixDQUFDOzs7QUFHMUYsTUFBTSxPQUFnQix1QkFBdUI7SUFJekMsWUFDeUMsSUFBc0IsRUFDdEIsVUFBd0MsRUFFNUQsU0FBdUI7UUFISCxTQUFJLEdBQUosSUFBSSxDQUFrQjtRQUN0QixlQUFVLEdBQVYsVUFBVSxDQUE4QjtRQUU1RCxjQUFTLEdBQVQsU0FBUyxDQUFjO1FBTm5DLGFBQVEsR0FBNEIsSUFBSSxDQUFDO1FBUTlDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLENBQUM7SUFDckQsQ0FBQztJQUVELElBQ0ksRUFBRTtRQUNGLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQyxhQUFhLENBQUMsRUFBRSxJQUFJLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxFQUFFLENBQUM7SUFDekUsQ0FBQzs7cUhBaEJpQix1QkFBdUIsa0JBSzdCLGtCQUFrQixhQUNsQixVQUFVLGFBQ1YsWUFBWTt5R0FQTix1QkFBdUIsK0dBQzlCLG9CQUFvQiwyQkFBUyxXQUFXOzRGQURqQyx1QkFBdUI7a0JBRDVDLFNBQVM7OzBCQU1ELE1BQU07MkJBQUMsa0JBQWtCOzswQkFDekIsTUFBTTsyQkFBQyxVQUFVOzswQkFDakIsTUFBTTsyQkFBQyxZQUFZOzRDQUxmLFFBQVE7c0JBRGhCLFNBQVM7dUJBQUMsb0JBQW9CLEVBQUUsRUFBQyxJQUFJLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUM7Z0JBYTlELEVBQUU7c0JBREwsV0FBVzt1QkFBQyxJQUFJIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgICBEaXJlY3RpdmUsXG4gICAgRWxlbWVudFJlZixcbiAgICBIb3N0QmluZGluZyxcbiAgICBJbmplY3QsXG4gICAgVGVtcGxhdGVSZWYsXG4gICAgVmlld0NoaWxkLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VHVpSWRTZXJ2aWNlfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7VFVJX1RFWFRGSUVMRF9IT1NULCBUdWlEYXRhTGlzdERpcmVjdGl2ZSwgVHVpVGV4dGZpZWxkSG9zdH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBBYnN0cmFjdFR1aU5hdGl2ZVNlbGVjdCB7XG4gICAgQFZpZXdDaGlsZChUdWlEYXRhTGlzdERpcmVjdGl2ZSwge3JlYWQ6IFRlbXBsYXRlUmVmLCBzdGF0aWM6IHRydWV9KVxuICAgIHJlYWRvbmx5IGRhdGFsaXN0OiBUZW1wbGF0ZVJlZjxhbnk+IHwgbnVsbCA9IG51bGw7XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChUVUlfVEVYVEZJRUxEX0hPU1QpIHJlYWRvbmx5IGhvc3Q6IFR1aVRleHRmaWVsZEhvc3QsXG4gICAgICAgIEBJbmplY3QoRWxlbWVudFJlZikgcHJpdmF0ZSByZWFkb25seSBlbGVtZW50UmVmOiBFbGVtZW50UmVmPEhUTUxJbnB1dEVsZW1lbnQ+LFxuICAgICAgICBASW5qZWN0KFR1aUlkU2VydmljZSlcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSBpZFNlcnZpY2U6IFR1aUlkU2VydmljZSxcbiAgICApIHtcbiAgICAgICAgdGhpcy5ob3N0LnByb2Nlc3ModGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQpO1xuICAgIH1cblxuICAgIEBIb3N0QmluZGluZyhgaWRgKVxuICAgIGdldCBpZCgpOiBzdHJpbmcge1xuICAgICAgICByZXR1cm4gdGhpcy5lbGVtZW50UmVmLm5hdGl2ZUVsZW1lbnQuaWQgfHwgdGhpcy5pZFNlcnZpY2UuZ2VuZXJhdGUoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, Inject, Input, Optional, Self, TemplateRef, ViewChild, } from '@angular/core';
|
|
3
3
|
import { NgControl } from '@angular/forms';
|
|
4
|
-
import { AbstractTuiNullableControl, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, tuiIsNativeFocused, } from '@taiga-ui/cdk';
|
|
4
|
+
import { AbstractTuiNullableControl, TUI_IS_MOBILE, tuiAsControl, tuiAsFocusableItemAccessor, tuiDefaultProp, tuiIsNativeFocused, } from '@taiga-ui/cdk';
|
|
5
5
|
import { TUI_TEXTFIELD_CLEANER, tuiAsDataListHost, tuiAsOptionContent, TuiDataListDirective, TuiHostedDropdownComponent, TuiPrimitiveTextfieldComponent, } from '@taiga-ui/core';
|
|
6
6
|
import { TUI_ARROW_MODE } from '@taiga-ui/kit/components/arrow';
|
|
7
7
|
import { TUI_SELECT_OPTION } from '@taiga-ui/kit/components/select-option';
|
|
8
8
|
import { FIXED_DROPDOWN_CONTROLLER_PROVIDER } from '@taiga-ui/kit/providers';
|
|
9
9
|
import { TUI_ITEMS_HANDLERS } from '@taiga-ui/kit/tokens';
|
|
10
|
+
import { AbstractTuiNativeSelect } from './native-select/native-select';
|
|
10
11
|
import { TUI_SELECT_OPTIONS } from './select-options';
|
|
11
12
|
import * as i0 from "@angular/core";
|
|
12
13
|
import * as i1 from "@taiga-ui/core";
|
|
@@ -15,12 +16,13 @@ import * as i3 from "@angular/common";
|
|
|
15
16
|
import * as i4 from "@tinkoff/ng-polymorpheus";
|
|
16
17
|
import * as i5 from "@angular/forms";
|
|
17
18
|
export class TuiSelectComponent extends AbstractTuiNullableControl {
|
|
18
|
-
constructor(control, changeDetectorRef, textfieldCleaner, arrowMode, itemsHandlers, options) {
|
|
19
|
+
constructor(control, changeDetectorRef, textfieldCleaner, arrowMode, itemsHandlers, options, isMobile) {
|
|
19
20
|
super(control, changeDetectorRef);
|
|
20
21
|
this.textfieldCleaner = textfieldCleaner;
|
|
21
22
|
this.arrowMode = arrowMode;
|
|
22
23
|
this.itemsHandlers = itemsHandlers;
|
|
23
24
|
this.options = options;
|
|
25
|
+
this.isMobile = isMobile;
|
|
24
26
|
this.stringify = this.itemsHandlers.stringify;
|
|
25
27
|
this.identityMatcher = this.itemsHandlers.identityMatcher;
|
|
26
28
|
this.valueContent = this.options.valueContent;
|
|
@@ -36,6 +38,9 @@ export class TuiSelectComponent extends AbstractTuiNullableControl {
|
|
|
36
38
|
return (tuiIsNativeFocused(this.nativeFocusableElement) ||
|
|
37
39
|
(!!this.hostedDropdown && this.hostedDropdown.focused));
|
|
38
40
|
}
|
|
41
|
+
get nativeDropdownMode() {
|
|
42
|
+
return !!this.nativeSelect && this.isMobile;
|
|
43
|
+
}
|
|
39
44
|
get computedValue() {
|
|
40
45
|
return this.value === null ? `` : this.stringify(this.value) || ` `;
|
|
41
46
|
}
|
|
@@ -46,6 +51,9 @@ export class TuiSelectComponent extends AbstractTuiNullableControl {
|
|
|
46
51
|
if (!value) {
|
|
47
52
|
this.updateValue(null);
|
|
48
53
|
}
|
|
54
|
+
else {
|
|
55
|
+
this.updateValue(value || null);
|
|
56
|
+
}
|
|
49
57
|
}
|
|
50
58
|
onActiveZone(active) {
|
|
51
59
|
this.updateFocused(active);
|
|
@@ -67,13 +75,13 @@ export class TuiSelectComponent extends AbstractTuiNullableControl {
|
|
|
67
75
|
}
|
|
68
76
|
}
|
|
69
77
|
}
|
|
70
|
-
TuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiSelectComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_TEXTFIELD_CLEANER }, { token: TUI_ARROW_MODE }, { token: TUI_ITEMS_HANDLERS }, { token: TUI_SELECT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
78
|
+
TuiSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiSelectComponent, deps: [{ token: NgControl, optional: true, self: true }, { token: ChangeDetectorRef }, { token: TUI_TEXTFIELD_CLEANER }, { token: TUI_ARROW_MODE }, { token: TUI_ITEMS_HANDLERS }, { token: TUI_SELECT_OPTIONS }, { token: TUI_IS_MOBILE }], target: i0.ɵɵFactoryTarget.Component });
|
|
71
79
|
TuiSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiSelectComponent, selector: "tui-select", inputs: { stringify: "stringify", identityMatcher: "identityMatcher", valueContent: "valueContent" }, providers: [
|
|
72
80
|
tuiAsFocusableItemAccessor(TuiSelectComponent),
|
|
73
81
|
tuiAsControl(TuiSelectComponent),
|
|
74
82
|
tuiAsDataListHost(TuiSelectComponent),
|
|
75
83
|
tuiAsOptionContent(TUI_SELECT_OPTION),
|
|
76
|
-
], queries: [{ propertyName: "datalist", first: true, predicate: TuiDataListDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }, { propertyName: "hostedDropdown", first: true, predicate: TuiHostedDropdownComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive\"\n [content]=\"datalist || ''\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n automation-id=\"tui-select__textfield\"\n class=\"t-textfield\"\n [tuiTextfieldIcon]=\"arrow\"\n [editable]=\"false\"\n [pseudoFocus]=\"computedFocused\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [invalid]=\"computedInvalid\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"computedFocusable\"\n [value]=\"computedValue\"\n (valueChange)=\"onValueChange($event)\"\n (keydown.delete.prevent)=\"onKeyDownDelete()\"\n (keydown.backspace.prevent)=\"onKeyDownDelete()\"\n >\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n <div\n *ngIf=\"value !== null\"\n ngProjectAs=\"tuiContent\"\n automation-id=\"tui-select__value\"\n class=\"t-value\"\n >\n <div\n *polymorpheusOutlet=\"computedContent as text; context: {$implicit: value, active: computedFocused}\"\n class=\"t-primitive-value\"\n [textContent]=\"text\"\n ></div>\n </div>\n </tui-primitive-textfield>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}:host:not(._readonly) ::ng-deep input:not(:disabled){cursor:pointer}:host._readonly ::ng-deep input{cursor:default}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-value{display:flex;width:100%;align-items:center}.t-primitive-value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }], directives: [{ type: i2.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
84
|
+
], queries: [{ propertyName: "nativeSelect", first: true, predicate: AbstractTuiNativeSelect, descendants: true, static: true }, { propertyName: "datalist", first: true, predicate: TuiDataListDirective, descendants: true, read: TemplateRef }], viewQueries: [{ propertyName: "textfield", first: true, predicate: TuiPrimitiveTextfieldComponent, descendants: true }, { propertyName: "hostedDropdown", first: true, predicate: TuiHostedDropdownComponent, descendants: true }], usesInheritance: true, ngImport: i0, template: "<tui-hosted-dropdown\n class=\"t-hosted\"\n [canOpen]=\"interactive && !nativeDropdownMode\"\n [content]=\"datalist || ''\"\n (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n <tui-primitive-textfield\n automation-id=\"tui-select__textfield\"\n class=\"t-textfield\"\n [tuiTextfieldIcon]=\"arrow\"\n [editable]=\"false\"\n [pseudoFocus]=\"computedFocused\"\n [pseudoHover]=\"pseudoHover\"\n [pseudoActive]=\"pseudoActive\"\n [invalid]=\"computedInvalid\"\n [nativeId]=\"nativeId\"\n [readOnly]=\"readOnly\"\n [disabled]=\"computedDisabled\"\n [focusable]=\"computedFocusable\"\n [value]=\"computedValue\"\n (valueChange)=\"onValueChange($any($event))\"\n (keydown.delete.prevent)=\"onKeyDownDelete()\"\n (keydown.backspace.prevent)=\"onKeyDownDelete()\"\n >\n <ng-content></ng-content>\n <ng-content\n select=\"input\"\n ngProjectAs=\"input\"\n ></ng-content>\n\n <ng-template #select>\n <ng-container *ngIf=\"isMobile\">\n <ng-content\n select=\"select\"\n ngProjectAs=\"select\"\n ></ng-content>\n </ng-container>\n </ng-template>\n\n <ng-container\n *ngTemplateOutlet=\"select\"\n ngProjectAs=\"select\"\n ></ng-container>\n\n <div\n *ngIf=\"value !== null\"\n ngProjectAs=\"tuiContent\"\n automation-id=\"tui-select__value\"\n class=\"t-value\"\n >\n <div\n *polymorpheusOutlet=\"computedContent as text; context: {$implicit: value, active: computedFocused}\"\n class=\"t-primitive-value\"\n [textContent]=\"text\"\n ></div>\n </div>\n </tui-primitive-textfield>\n</tui-hosted-dropdown>\n", styles: [":host{display:block;border-radius:var(--tui-radius-m);text-align:left}:host:not(._readonly) ::ng-deep input:not(:disabled){cursor:pointer}:host._readonly ::ng-deep input{cursor:default}.t-hosted{display:block;border-radius:inherit}.t-textfield{border-radius:inherit;text-align:inherit}.t-value{display:flex;width:100%;align-items:center}.t-primitive-value{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}\n"], components: [{ type: i1.TuiHostedDropdownComponent, selector: "tui-hosted-dropdown", inputs: ["content", "canOpen", "open"], outputs: ["openChange", "focusedChange"] }, { type: i1.TuiPrimitiveTextfieldComponent, selector: "tui-primitive-textfield", inputs: ["editable", "filler", "iconCleaner", "readOnly", "invalid", "disabled", "prefix", "postfix", "value"], outputs: ["valueChange"] }], directives: [{ type: i2.TuiActiveZoneDirective, selector: "[tuiActiveZone]:not(ng-container), [tuiActiveZoneChange]:not(ng-container), [tuiActiveZoneParent]:not(ng-container)", inputs: ["tuiActiveZoneParent"], outputs: ["tuiActiveZoneChange"], exportAs: ["tuiActiveZone"] }, { type: i1.TuiPrimitiveTextfieldDirective, selector: "tui-primitive-textfield" }, { type: i1.TuiTextfieldIconDirective, selector: "[tuiTextfieldIcon]", inputs: ["tuiTextfieldIcon"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.PolymorpheusOutletDirective, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }], viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
77
85
|
__decorate([
|
|
78
86
|
tuiDefaultProp()
|
|
79
87
|
], TuiSelectComponent.prototype, "stringify", void 0);
|
|
@@ -120,12 +128,18 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
120
128
|
}] }, { type: undefined, decorators: [{
|
|
121
129
|
type: Inject,
|
|
122
130
|
args: [TUI_SELECT_OPTIONS]
|
|
131
|
+
}] }, { type: undefined, decorators: [{
|
|
132
|
+
type: Inject,
|
|
133
|
+
args: [TUI_IS_MOBILE]
|
|
123
134
|
}] }]; }, propDecorators: { textfield: [{
|
|
124
135
|
type: ViewChild,
|
|
125
136
|
args: [TuiPrimitiveTextfieldComponent]
|
|
126
137
|
}], hostedDropdown: [{
|
|
127
138
|
type: ViewChild,
|
|
128
139
|
args: [TuiHostedDropdownComponent]
|
|
140
|
+
}], nativeSelect: [{
|
|
141
|
+
type: ContentChild,
|
|
142
|
+
args: [AbstractTuiNativeSelect, { static: true }]
|
|
129
143
|
}], stringify: [{
|
|
130
144
|
type: Input
|
|
131
145
|
}], identityMatcher: [{
|
|
@@ -136,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
136
150
|
type: ContentChild,
|
|
137
151
|
args: [TuiDataListDirective, { read: TemplateRef }]
|
|
138
152
|
}] } });
|
|
139
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/select/select.component.ts","../../../../../projects/kit/components/select/select.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_TEXTFIELD_CLEANER,\n    tuiAsDataListHost,\n    tuiAsOptionContent,\n    TuiDataListDirective,\n    TuiDataListHost,\n    TuiHostedDropdownComponent,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeM,\n    TuiSizeS,\n    TuiTextfieldCleanerDirective,\n    TuiValueContentContext,\n} from '@taiga-ui/core';\nimport {TUI_ARROW_MODE, TuiArrowMode} from '@taiga-ui/kit/components/arrow';\nimport {TUI_SELECT_OPTION} from '@taiga-ui/kit/components/select-option';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_ITEMS_HANDLERS, TuiItemsHandlers} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\nimport {TUI_SELECT_OPTIONS, TuiSelectOptions} from './select-options';\n\n@Component({\n    selector: `tui-select`,\n    templateUrl: `./select.template.html`,\n    styleUrls: [`./select.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiSelectComponent),\n        tuiAsControl(TuiSelectComponent),\n        tuiAsDataListHost(TuiSelectComponent),\n        tuiAsOptionContent(TUI_SELECT_OPTION),\n    ],\n    viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],\n})\nexport class TuiSelectComponent<T>\n    extends AbstractTuiNullableControl<T>\n    implements TuiFocusableElementAccessor, TuiDataListHost<T>\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly hostedDropdown?: TuiHostedDropdownComponent;\n\n    @Input()\n    @tuiDefaultProp()\n    stringify: TuiItemsHandlers<T>['stringify'] = this.itemsHandlers.stringify;\n\n    @Input()\n    @tuiDefaultProp()\n    identityMatcher: TuiItemsHandlers<T>['identityMatcher'] =\n        this.itemsHandlers.identityMatcher;\n\n    @Input()\n    @tuiDefaultProp()\n    valueContent: TuiSelectOptions<T>['valueContent'] = this.options.valueContent;\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist: PolymorpheusContent<\n        TuiContextWithImplicit<TuiActiveZoneDirective>\n    > = ``;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_TEXTFIELD_CLEANER)\n        private readonly textfieldCleaner: TuiTextfieldCleanerDirective,\n        @Inject(TUI_ARROW_MODE)\n        private readonly arrowMode: TuiArrowMode,\n        @Inject(TUI_ITEMS_HANDLERS)\n        private readonly itemsHandlers: TuiItemsHandlers<T>,\n        @Inject(TUI_SELECT_OPTIONS)\n        private readonly options: TuiSelectOptions<T>,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get arrow(): PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeS | TuiSizeM | TuiSizeL>\n    > {\n        return !this.interactive ? this.arrowMode.disabled : this.arrowMode.interactive;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocused(this.nativeFocusableElement) ||\n            (!!this.hostedDropdown && this.hostedDropdown.focused)\n        );\n    }\n\n    get computedValue(): string {\n        return this.value === null ? `` : this.stringify(this.value) || ` `;\n    }\n\n    get computedContent(): PolymorpheusContent<TuiValueContentContext<T>> {\n        return this.valueContent || this.computedValue;\n    }\n\n    onValueChange(value: string): void {\n        if (!value) {\n            this.updateValue(null);\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n    }\n\n    onKeyDownDelete(): void {\n        if (this.textfieldCleaner.cleaner) {\n            this.updateValue(null);\n        }\n    }\n\n    handleOption(option: T): void {\n        this.focusInput();\n        this.updateValue(option);\n        this.hostedDropdown?.updateOpen(false);\n    }\n\n    private focusInput(preventScroll: boolean = false): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll});\n        }\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive\"\n    [content]=\"datalist || ''\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        automation-id=\"tui-select__textfield\"\n        class=\"t-textfield\"\n        [tuiTextfieldIcon]=\"arrow\"\n        [editable]=\"false\"\n        [pseudoFocus]=\"computedFocused\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoActive]=\"pseudoActive\"\n        [invalid]=\"computedInvalid\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"computedFocusable\"\n        [value]=\"computedValue\"\n        (valueChange)=\"onValueChange($event)\"\n        (keydown.delete.prevent)=\"onKeyDownDelete()\"\n        (keydown.backspace.prevent)=\"onKeyDownDelete()\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n        <div\n            *ngIf=\"value !== null\"\n            ngProjectAs=\"tuiContent\"\n            automation-id=\"tui-select__value\"\n            class=\"t-value\"\n        >\n            <div\n                *polymorpheusOutlet=\"computedContent as text; context: {$implicit: value, active: computedFocused}\"\n                class=\"t-primitive-value\"\n                [textContent]=\"text\"\n            ></div>\n        </div>\n    </tui-primitive-textfield>\n</tui-hosted-dropdown>\n"]}
|
|
153
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/kit/components/select/select.component.ts","../../../../../projects/kit/components/select/select.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ContentChild,\n    Inject,\n    Input,\n    Optional,\n    Self,\n    TemplateRef,\n    ViewChild,\n} from '@angular/core';\nimport {NgControl} from '@angular/forms';\nimport {\n    AbstractTuiNullableControl,\n    TUI_IS_MOBILE,\n    TuiActiveZoneDirective,\n    tuiAsControl,\n    tuiAsFocusableItemAccessor,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiFocusableElementAccessor,\n    tuiIsNativeFocused,\n} from '@taiga-ui/cdk';\nimport {\n    TUI_TEXTFIELD_CLEANER,\n    tuiAsDataListHost,\n    tuiAsOptionContent,\n    TuiDataListDirective,\n    TuiDataListHost,\n    TuiHostedDropdownComponent,\n    TuiPrimitiveTextfieldComponent,\n    TuiSizeL,\n    TuiSizeM,\n    TuiSizeS,\n    TuiTextfieldCleanerDirective,\n    TuiValueContentContext,\n} from '@taiga-ui/core';\nimport {TUI_ARROW_MODE, TuiArrowMode} from '@taiga-ui/kit/components/arrow';\nimport {TUI_SELECT_OPTION} from '@taiga-ui/kit/components/select-option';\nimport {FIXED_DROPDOWN_CONTROLLER_PROVIDER} from '@taiga-ui/kit/providers';\nimport {TUI_ITEMS_HANDLERS, TuiItemsHandlers} from '@taiga-ui/kit/tokens';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\nimport {AbstractTuiNativeSelect} from './native-select/native-select';\nimport {TUI_SELECT_OPTIONS, TuiSelectOptions} from './select-options';\n\n@Component({\n    selector: `tui-select`,\n    templateUrl: `./select.template.html`,\n    styleUrls: [`./select.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        tuiAsFocusableItemAccessor(TuiSelectComponent),\n        tuiAsControl(TuiSelectComponent),\n        tuiAsDataListHost(TuiSelectComponent),\n        tuiAsOptionContent(TUI_SELECT_OPTION),\n    ],\n    viewProviders: [FIXED_DROPDOWN_CONTROLLER_PROVIDER],\n})\nexport class TuiSelectComponent<T>\n    extends AbstractTuiNullableControl<T>\n    implements TuiFocusableElementAccessor, TuiDataListHost<T>\n{\n    @ViewChild(TuiPrimitiveTextfieldComponent)\n    private readonly textfield?: TuiPrimitiveTextfieldComponent;\n\n    @ViewChild(TuiHostedDropdownComponent)\n    private readonly hostedDropdown?: TuiHostedDropdownComponent;\n\n    @ContentChild(AbstractTuiNativeSelect, {static: true})\n    private readonly nativeSelect?: AbstractTuiNativeSelect;\n\n    @Input()\n    @tuiDefaultProp()\n    stringify: TuiItemsHandlers<T>['stringify'] = this.itemsHandlers.stringify;\n\n    @Input()\n    @tuiDefaultProp()\n    identityMatcher: TuiItemsHandlers<T>['identityMatcher'] =\n        this.itemsHandlers.identityMatcher;\n\n    @Input()\n    @tuiDefaultProp()\n    valueContent: TuiSelectOptions<T>['valueContent'] = this.options.valueContent;\n\n    @ContentChild(TuiDataListDirective, {read: TemplateRef})\n    readonly datalist: PolymorpheusContent<\n        TuiContextWithImplicit<TuiActiveZoneDirective>\n    > = ``;\n\n    constructor(\n        @Optional()\n        @Self()\n        @Inject(NgControl)\n        control: NgControl | null,\n        @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n        @Inject(TUI_TEXTFIELD_CLEANER)\n        private readonly textfieldCleaner: TuiTextfieldCleanerDirective,\n        @Inject(TUI_ARROW_MODE)\n        private readonly arrowMode: TuiArrowMode,\n        @Inject(TUI_ITEMS_HANDLERS)\n        private readonly itemsHandlers: TuiItemsHandlers<T>,\n        @Inject(TUI_SELECT_OPTIONS)\n        private readonly options: TuiSelectOptions<T>,\n        @Inject(TUI_IS_MOBILE)\n        readonly isMobile: boolean,\n    ) {\n        super(control, changeDetectorRef);\n    }\n\n    get arrow(): PolymorpheusContent<\n        TuiContextWithImplicit<TuiSizeS | TuiSizeM | TuiSizeL>\n    > {\n        return !this.interactive ? this.arrowMode.disabled : this.arrowMode.interactive;\n    }\n\n    get nativeFocusableElement(): HTMLInputElement | null {\n        return this.textfield ? this.textfield.nativeFocusableElement : null;\n    }\n\n    get focused(): boolean {\n        return (\n            tuiIsNativeFocused(this.nativeFocusableElement) ||\n            (!!this.hostedDropdown && this.hostedDropdown.focused)\n        );\n    }\n\n    get nativeDropdownMode(): boolean {\n        return !!this.nativeSelect && this.isMobile;\n    }\n\n    get computedValue(): string {\n        return this.value === null ? `` : this.stringify(this.value) || ` `;\n    }\n\n    get computedContent(): PolymorpheusContent<TuiValueContentContext<T>> {\n        return this.valueContent || this.computedValue;\n    }\n\n    onValueChange(value: T): void {\n        if (!value) {\n            this.updateValue(null);\n        } else {\n            this.updateValue(value || null);\n        }\n    }\n\n    onActiveZone(active: boolean): void {\n        this.updateFocused(active);\n    }\n\n    onKeyDownDelete(): void {\n        if (this.textfieldCleaner.cleaner) {\n            this.updateValue(null);\n        }\n    }\n\n    handleOption(option: T): void {\n        this.focusInput();\n        this.updateValue(option);\n        this.hostedDropdown?.updateOpen(false);\n    }\n\n    private focusInput(preventScroll: boolean = false): void {\n        if (this.nativeFocusableElement) {\n            this.nativeFocusableElement.focus({preventScroll});\n        }\n    }\n}\n","<tui-hosted-dropdown\n    class=\"t-hosted\"\n    [canOpen]=\"interactive && !nativeDropdownMode\"\n    [content]=\"datalist || ''\"\n    (tuiActiveZoneChange)=\"onActiveZone($event)\"\n>\n    <tui-primitive-textfield\n        automation-id=\"tui-select__textfield\"\n        class=\"t-textfield\"\n        [tuiTextfieldIcon]=\"arrow\"\n        [editable]=\"false\"\n        [pseudoFocus]=\"computedFocused\"\n        [pseudoHover]=\"pseudoHover\"\n        [pseudoActive]=\"pseudoActive\"\n        [invalid]=\"computedInvalid\"\n        [nativeId]=\"nativeId\"\n        [readOnly]=\"readOnly\"\n        [disabled]=\"computedDisabled\"\n        [focusable]=\"computedFocusable\"\n        [value]=\"computedValue\"\n        (valueChange)=\"onValueChange($any($event))\"\n        (keydown.delete.prevent)=\"onKeyDownDelete()\"\n        (keydown.backspace.prevent)=\"onKeyDownDelete()\"\n    >\n        <ng-content></ng-content>\n        <ng-content\n            select=\"input\"\n            ngProjectAs=\"input\"\n        ></ng-content>\n\n        <ng-template #select>\n            <ng-container *ngIf=\"isMobile\">\n                <ng-content\n                    select=\"select\"\n                    ngProjectAs=\"select\"\n                ></ng-content>\n            </ng-container>\n        </ng-template>\n\n        <ng-container\n            *ngTemplateOutlet=\"select\"\n            ngProjectAs=\"select\"\n        ></ng-container>\n\n        <div\n            *ngIf=\"value !== null\"\n            ngProjectAs=\"tuiContent\"\n            automation-id=\"tui-select__value\"\n            class=\"t-value\"\n        >\n            <div\n                *polymorpheusOutlet=\"computedContent as text; context: {$implicit: value, active: computedFocused}\"\n                class=\"t-primitive-value\"\n                [textContent]=\"text\"\n            ></div>\n        </div>\n    </tui-primitive-textfield>\n</tui-hosted-dropdown>\n"]}
|