@snabcentr/client-ui 1.6.1 → 1.6.3

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,8 +1,9 @@
1
1
  import { HttpErrorResponse } from '@angular/common/http';
2
- import { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, Output, SkipSelf } from '@angular/core';
2
+ import { ChangeDetectionStrategy, Component, EventEmitter, Inject, inject, Input, Output, SkipSelf } from '@angular/core';
3
3
  import { NgControl } from '@angular/forms';
4
4
  import { ScISuggestionType } from '@snabcentr/client-core';
5
5
  import { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';
6
+ import { TUI_DATA_LIST_HOST } from '@taiga-ui/core';
6
7
  import { catchError, debounceTime, filter, map, of, share, startWith, switchMap, throwError } from 'rxjs';
7
8
  import * as i0 from "@angular/core";
8
9
  import * as i1 from "@snabcentr/client-core";
@@ -35,6 +36,12 @@ export class ScSuggestionFieldComponent {
35
36
  * Перечисление типов подсказок.
36
37
  */
37
38
  this.suggestionType = ScISuggestionType;
39
+ /**
40
+ * Компонент обёртка выпадающего списка.
41
+ */
42
+ this.host = inject(TUI_DATA_LIST_HOST, {
43
+ optional: true,
44
+ });
38
45
  }
39
46
  /** @inheritDoc */
40
47
  ngOnInit() {
@@ -62,12 +69,12 @@ export class ScSuggestionFieldComponent {
62
69
  switch (this.type) {
63
70
  case ScISuggestionType.fio:
64
71
  if ('fio' in suggestion) {
65
- this.control.control?.patchValue(suggestion.fio);
72
+ this.control.control?.patchValue(suggestion.fio, { emitEvent: false });
66
73
  }
67
74
  break;
68
75
  case ScISuggestionType.address:
69
76
  if ('addressString' in suggestion) {
70
- this.control.control?.patchValue(suggestion.addressString);
77
+ this.control.control?.patchValue(suggestion.addressString, { emitEvent: false });
71
78
  }
72
79
  break;
73
80
  case ScISuggestionType.bank:
@@ -76,7 +83,7 @@ export class ScSuggestionFieldComponent {
76
83
  bankName: suggestion.name,
77
84
  bic: suggestion.bic,
78
85
  correspondentAccount: suggestion.correspondentAccount,
79
- });
86
+ }, { emitEvent: false });
80
87
  }
81
88
  break;
82
89
  case ScISuggestionType.organization:
@@ -91,17 +98,19 @@ export class ScSuggestionFieldComponent {
91
98
  legalAddress: suggestion.legalAddress,
92
99
  postalAddress: suggestion.postalAddress,
93
100
  actualAddress: suggestion.actualAddress,
94
- });
101
+ }, { emitEvent: false });
95
102
  }
96
103
  break;
97
104
  case ScISuggestionType.email:
98
105
  if ('email' in suggestion) {
99
- this.control.control?.patchValue(suggestion.email);
106
+ this.control.control?.patchValue(suggestion.email, { emitEvent: false });
100
107
  }
101
108
  break;
102
109
  default:
103
110
  break;
104
111
  }
112
+ // Дёргаем внутренний обработчик выбора элемента выпадающего списка.
113
+ this.host?.handleOption(this.control.value);
105
114
  this.selectedClick.emit(suggestion);
106
115
  }
107
116
  }
@@ -120,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
120
129
  }], selectedClick: [{
121
130
  type: Output
122
131
  }] } });
123
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-suggestion-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.ts","../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Inject, Input, OnInit, Output, SkipSelf } from '@angular/core';\nimport { FormGroup, NgControl } from '@angular/forms';\nimport { ScISuggestionType, ScSuggestion, ScSuggestionService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { catchError, debounceTime, filter, map, Observable, of, share, startWith, switchMap, throwError } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\n\n/**\n * Компонент подсказок для поля ввода.\n */\n@Component({\n    selector: 'sc-suggestion-field',\n    templateUrl: './sc-suggestion-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSuggestionFieldComponent implements OnInit {\n    /**\n     * Тип подсказок.\n     */\n    @Input()\n    public type: ScISuggestionType = ScISuggestionType.fio;\n\n    /**\n     * Событие выбора результата подсказки.\n     */\n    @Output()\n    public selectedClick: EventEmitter<ScSuggestion> = new EventEmitter<ScSuggestion>();\n\n    /**\n     * {@link Observable} подсказок.\n     */\n    public suggestions$?: Observable<ScSuggestion[] | null>;\n\n    /**\n     * {@link Observable} состояние запроса подсказок.\n     */\n    public loading$?: Observable<boolean>;\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSuggestionFieldComponent}.\n     *\n     * @param control Контрол поля ввода.\n     * @param suggestionService Сервис работы с API подсказок.\n     */\n    public constructor(\n        @SkipSelf()\n        @Inject(NgControl)\n        public readonly control: NgControl,\n        private readonly suggestionService: ScSuggestionService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        const request$ = tuiControlValue<string | null>(this.control).pipe(\n            debounceTime(500),\n            filter(tuiIsPresent),\n            map((term) => term.trim()),\n            filter((term) => term.length >= 3),\n            switchMap((term: string) => this.suggestionService.getData<ScSuggestion>(term, this.type).pipe(startWith(null))),\n            catchError((error: unknown) => {\n                if (error instanceof HttpErrorResponse) {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    if (this.control.control) {\n                        tuiMarkControlAsTouchedAndValidate(this.control.control);\n\n                        this.control.control.setErrors({\n                            serverResponse: [errorResponse.message || 'Ошибка сервера: пожалуйста, перезагрузите страницу и/или выполните запрос позже.'],\n                        });\n                    }\n                }\n\n                return throwError(() => of([]));\n            }),\n            share()\n        );\n\n        this.suggestions$ = request$.pipe(filter(tuiIsPresent), startWith(null));\n        this.loading$ = request$.pipe(map(tuiIsFalsy));\n    }\n\n    /**\n     * Заполнение полей основе выбранной подсказки.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public onSelected(suggestion: ScSuggestion): void {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n                if ('fio' in suggestion) {\n                    this.control.control?.patchValue(suggestion.fio);\n                }\n                break;\n            case ScISuggestionType.address:\n                if ('addressString' in suggestion) {\n                    this.control.control?.patchValue(suggestion.addressString);\n                }\n                break;\n            case ScISuggestionType.bank:\n                if ('inn' in suggestion && 'bic' in suggestion) {\n                    (this.control.control?.parent as FormGroup).patchValue({\n                        bankName: suggestion.name,\n                        bic: suggestion.bic,\n                        correspondentAccount: suggestion.correspondentAccount,\n                    });\n                }\n                break;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    (this.control.control?.parent as FormGroup).patchValue({\n                        name: suggestion.name,\n                        inn: suggestion.inn,\n                        kpp: suggestion.kpp,\n                        okpo: suggestion.okpo,\n                        directorName: suggestion.directorName,\n                        directorPosition: suggestion.directorPosition,\n                        legalAddress: suggestion.legalAddress,\n                        postalAddress: suggestion.postalAddress,\n                        actualAddress: suggestion.actualAddress,\n                    });\n                }\n                break;\n            case ScISuggestionType.email:\n                if ('email' in suggestion) {\n                    this.control.control?.patchValue(suggestion.email);\n                }\n                break;\n            default:\n                break;\n        }\n\n        this.selectedClick.emit(suggestion);\n    }\n}\n","<tui-loader\n    size=\"m\"\n    [overlay]=\"true\"\n    [showLoader]=\"!!(loading$ | async)\"\n>\n    <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n        <button\n            *ngFor=\"let option of options\"\n            tuiOption\n            (click)=\"onSelected(option)\"\n            class=\"flex-col !items-start\"\n        >\n            <ng-container *tuiLet=\"$any(option) as option\">\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchCase=\"suggestionType.fio\">\n                        <span class=\"text-tui-link\">{{ option.fio }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.organization\">\n                        <span class=\"text-tui-link\">\n                            {{ option.name }}\n                            <span class=\"ml-2 text-tui-text-02\">инн: {{ option.inn }}</span>\n                        </span>\n                        <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.bank\">\n                        <span class=\"text-tui-link\">{{ option.name }}</span>\n                        <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.email\">\n                        <span class=\"text-tui-link\">{{ option.email }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.address\">\n                        <span class=\"text-tui-link\">{{ option.addressString }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-container>\n        </button>\n    </tui-data-list>\n</tui-loader>\n"]}
132
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-suggestion-field.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.ts","../../../../../projects/client-ui/form-fields/suggestion-field/sc-suggestion-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Inject, inject, Input, OnInit, Output, SkipSelf } from '@angular/core';\nimport { FormGroup, NgControl } from '@angular/forms';\nimport { ScISuggestionType, ScSuggestion, ScSuggestionService } from '@snabcentr/client-core';\nimport { tuiControlValue, tuiIsFalsy, tuiIsPresent, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TUI_DATA_LIST_HOST, TuiDataListHost } from '@taiga-ui/core';\nimport { catchError, debounceTime, filter, map, Observable, of, share, startWith, switchMap, throwError } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\n\n/**\n * Компонент подсказок для поля ввода.\n */\n@Component({\n    selector: 'sc-suggestion-field',\n    templateUrl: './sc-suggestion-field.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSuggestionFieldComponent implements OnInit {\n    /**\n     * Тип подсказок.\n     */\n    @Input()\n    public type: ScISuggestionType = ScISuggestionType.fio;\n\n    /**\n     * Событие выбора результата подсказки.\n     */\n    @Output()\n    public selectedClick: EventEmitter<ScSuggestion> = new EventEmitter<ScSuggestion>();\n\n    /**\n     * {@link Observable} подсказок.\n     */\n    public suggestions$?: Observable<ScSuggestion[] | null>;\n\n    /**\n     * {@link Observable} состояние запроса подсказок.\n     */\n    public loading$?: Observable<boolean>;\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * Компонент обёртка выпадающего списка.\n     */\n    private readonly host: TuiDataListHost<unknown> | null = inject<TuiDataListHost<unknown>>(TUI_DATA_LIST_HOST, {\n        optional: true,\n    });\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSuggestionFieldComponent}.\n     *\n     * @param control Контрол поля ввода.\n     * @param suggestionService Сервис работы с API подсказок.\n     */\n    public constructor(\n        @SkipSelf()\n        @Inject(NgControl)\n        public readonly control: NgControl,\n        private readonly suggestionService: ScSuggestionService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        const request$ = tuiControlValue<string | null>(this.control).pipe(\n            debounceTime(500),\n            filter(tuiIsPresent),\n            map((term) => term.trim()),\n            filter((term) => term.length >= 3),\n            switchMap((term: string) => this.suggestionService.getData<ScSuggestion>(term, this.type).pipe(startWith(null))),\n            catchError((error: unknown) => {\n                if (error instanceof HttpErrorResponse) {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    if (this.control.control) {\n                        tuiMarkControlAsTouchedAndValidate(this.control.control);\n\n                        this.control.control.setErrors({\n                            serverResponse: [errorResponse.message || 'Ошибка сервера: пожалуйста, перезагрузите страницу и/или выполните запрос позже.'],\n                        });\n                    }\n                }\n\n                return throwError(() => of([]));\n            }),\n            share()\n        );\n\n        this.suggestions$ = request$.pipe(filter(tuiIsPresent), startWith(null));\n        this.loading$ = request$.pipe(map(tuiIsFalsy));\n    }\n\n    /**\n     * Заполнение полей основе выбранной подсказки.\n     *\n     * @param suggestion Объект подсказки.\n     */\n    public onSelected(suggestion: ScSuggestion): void {\n        switch (this.type) {\n            case ScISuggestionType.fio:\n                if ('fio' in suggestion) {\n                    this.control.control?.patchValue(suggestion.fio, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.address:\n                if ('addressString' in suggestion) {\n                    this.control.control?.patchValue(suggestion.addressString, { emitEvent: false });\n                }\n                break;\n            case ScISuggestionType.bank:\n                if ('inn' in suggestion && 'bic' in suggestion) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            bankName: suggestion.name,\n                            bic: suggestion.bic,\n                            correspondentAccount: suggestion.correspondentAccount,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.organization:\n                if ('inn' in suggestion && !('bic' in suggestion)) {\n                    (this.control.control?.parent as FormGroup).patchValue(\n                        {\n                            name: suggestion.name,\n                            inn: suggestion.inn,\n                            kpp: suggestion.kpp,\n                            okpo: suggestion.okpo,\n                            directorName: suggestion.directorName,\n                            directorPosition: suggestion.directorPosition,\n                            legalAddress: suggestion.legalAddress,\n                            postalAddress: suggestion.postalAddress,\n                            actualAddress: suggestion.actualAddress,\n                        },\n                        { emitEvent: false }\n                    );\n                }\n                break;\n            case ScISuggestionType.email:\n                if ('email' in suggestion) {\n                    this.control.control?.patchValue(suggestion.email, { emitEvent: false });\n                }\n                break;\n            default:\n                break;\n        }\n\n        // Дёргаем внутренний обработчик выбора элемента выпадающего списка.\n        this.host?.handleOption(this.control.value);\n        this.selectedClick.emit(suggestion);\n    }\n}\n","<tui-loader\n    size=\"m\"\n    [overlay]=\"true\"\n    [showLoader]=\"!!(loading$ | async)\"\n>\n    <tui-data-list *tuiLet=\"suggestions$ | async as options\">\n        <button\n            *ngFor=\"let option of options\"\n            tuiOption\n            (click)=\"onSelected(option)\"\n            class=\"flex-col !items-start\"\n        >\n            <ng-container *tuiLet=\"$any(option) as option\">\n                <ng-container [ngSwitch]=\"type\">\n                    <ng-container *ngSwitchCase=\"suggestionType.fio\">\n                        <span class=\"text-tui-link\">{{ option.fio }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.organization\">\n                        <span class=\"text-tui-link\">\n                            {{ option.name }}\n                            <span class=\"ml-2 text-tui-text-02\">инн: {{ option.inn }}</span>\n                        </span>\n                        <span class=\"text-tui-text-02\">{{ option?.legalAddress }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.bank\">\n                        <span class=\"text-tui-link\">{{ option.name }}</span>\n                        <span class=\"text-tui-text-02\">{{ option.bic }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.email\">\n                        <span class=\"text-tui-link\">{{ option.email }}</span>\n                    </ng-container>\n                    <ng-container *ngSwitchCase=\"suggestionType.address\">\n                        <span class=\"text-tui-link\">{{ option.addressString }}</span>\n                    </ng-container>\n                </ng-container>\n            </ng-container>\n        </button>\n    </tui-data-list>\n</tui-loader>\n"]}
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
1
+ import { ChangeDetectionStrategy, Component, HostBinding, Inject } from '@angular/core';
2
2
  import { IS_RUNNING_ON_TERMINAL } from '@snabcentr/client-core';
3
3
  import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
4
4
  import * as i0 from "@angular/core";
@@ -19,6 +19,10 @@ export class ScQRCodeDialogComponent {
19
19
  this.vCardService = vCardService;
20
20
  this.context = context;
21
21
  this.terminal = terminal;
22
+ /**
23
+ * Свойство, от которого зависит наличие атрибута `data-terminal-view` у `:host` компонента.
24
+ */
25
+ this.terminalView = this.terminal.isRunningOnTerminal;
22
26
  }
23
27
  /**
24
28
  * Выполняет скачивание генерируемого vCard файла контакта.
@@ -37,15 +41,18 @@ export class ScQRCodeDialogComponent {
37
41
  }
38
42
  }
39
43
  ScQRCodeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScQRCodeDialogComponent, deps: [{ token: i1.ScVCardService }, { token: POLYMORPHEUS_CONTEXT }, { token: IS_RUNNING_ON_TERMINAL }], target: i0.ɵɵFactoryTarget.Component });
40
- ScQRCodeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScQRCodeDialogComponent, selector: "sc-qrcode-dialog", ngImport: i0, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ terminal.isRunningOnTerminal && this.isVCardData() ? '\u041E' : '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"], dependencies: [{ kind: "component", type: i2.QRCodeComponent, selector: "qrcode", inputs: ["allowEmptyString", "colorDark", "colorLight", "cssClass", "elementType", "errorCorrectionLevel", "imageSrc", "imageHeight", "imageWidth", "margin", "qrdata", "scale", "version", "width", "alt", "ariaLabel", "title"], outputs: ["qrCodeURL"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
44
+ ScQRCodeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScQRCodeDialogComponent, selector: "sc-qrcode-dialog", host: { properties: { "attr.data-terminal-view": "this.terminalView" } }, ngImport: i0, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ !terminal.isRunningOnTerminal && this.isVCardData() ? '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' : '\u041E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"], dependencies: [{ kind: "component", type: i2.QRCodeComponent, selector: "qrcode", inputs: ["allowEmptyString", "colorDark", "colorLight", "cssClass", "elementType", "errorCorrectionLevel", "imageSrc", "imageHeight", "imageWidth", "margin", "qrdata", "scale", "version", "width", "alt", "ariaLabel", "title"], outputs: ["qrCodeURL"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
41
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScQRCodeDialogComponent, decorators: [{
42
46
  type: Component,
43
- args: [{ selector: 'sc-qrcode-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ terminal.isRunningOnTerminal && this.isVCardData() ? '\u041E' : '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"] }]
47
+ args: [{ selector: 'sc-qrcode-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ !terminal.isRunningOnTerminal && this.isVCardData() ? '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' : '\u041E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"] }]
44
48
  }], ctorParameters: function () { return [{ type: i1.ScVCardService }, { type: undefined, decorators: [{
45
49
  type: Inject,
46
50
  args: [POLYMORPHEUS_CONTEXT]
47
51
  }] }, { type: undefined, decorators: [{
48
52
  type: Inject,
49
53
  args: [IS_RUNNING_ON_TERMINAL]
50
- }] }]; } });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcXJjb2RlL3FyY29kZS1kaWFsb2cvc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcXJjb2RlL3FyY29kZS1kaWFsb2cvc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsc0JBQXNCLEVBQXVDLE1BQU0sd0JBQXdCLENBQUM7QUFFckcsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFFaEU7O0dBRUc7QUFPSCxNQUFNLE9BQU8sdUJBQXVCO0lBQ2hDOzs7Ozs7T0FNRztJQUNILFlBQ3FCLFlBQTRCLEVBRTdCLE9BQW1ELEVBRW5ELFFBQTZCO1FBSjVCLGlCQUFZLEdBQVosWUFBWSxDQUFnQjtRQUU3QixZQUFPLEdBQVAsT0FBTyxDQUE0QztRQUVuRCxhQUFRLEdBQVIsUUFBUSxDQUFxQjtJQUM5QyxDQUFDO0lBRUo7O09BRUc7SUFDSSxhQUFhO1FBQ2hCLElBQUksQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLG1CQUFtQixJQUFJLElBQUksQ0FBQyxXQUFXLEVBQUUsRUFBRTtZQUMxRCxJQUFJLENBQUMsWUFBWSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUM3RDtJQUNMLENBQUM7SUFFRDs7T0FFRztJQUNJLFdBQVc7UUFDZCxnREFBZ0Q7UUFDaEQsT0FBTyw4QkFBOEIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDekUsQ0FBQzs7b0hBL0JRLHVCQUF1QixnREFVcEIsb0JBQW9CLGFBRXBCLHNCQUFzQjt3R0FaekIsdUJBQXVCLHdEQ2RwQyxnbkJBU0E7MkZES2EsdUJBQXVCO2tCQU5uQyxTQUFTOytCQUNJLGtCQUFrQixtQkFHWCx1QkFBdUIsQ0FBQyxNQUFNOzswQkFZMUMsTUFBTTsyQkFBQyxvQkFBb0I7OzBCQUUzQixNQUFNOzJCQUFDLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSVNfUlVOTklOR19PTl9URVJNSU5BTCwgU2NJVGVybWluYWxQcm92aWRlciwgU2NWQ2FyZFNlcnZpY2UgfSBmcm9tICdAc25hYmNlbnRyL2NsaWVudC1jb3JlJztcbmltcG9ydCB7IFR1aURpYWxvZ0NvbnRleHQgfSBmcm9tICdAdGFpZ2EtdWkvY29yZSc7XG5pbXBvcnQgeyBQT0xZTU9SUEhFVVNfQ09OVEVYVCB9IGZyb20gJ0B0aW5rb2ZmL25nLXBvbHltb3JwaGV1cyc7XG5cbi8qKlxuICog0JrQvtC80L/QvtC90LXQvdGCIFFSINC60L7QtNCwLlxuICovXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3NjLXFyY29kZS1kaWFsb2cnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9zYy1xcmNvZGUtZGlhbG9nLmNvbXBvbmVudC5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9zYy1xcmNvZGUtZGlhbG9nLmNvbXBvbmVudC5zY3NzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFNjUVJDb2RlRGlhbG9nQ29tcG9uZW50IHtcbiAgICAvKipcbiAgICAgKiDQmNC90LjRhtC40LDQu9C40LfQuNGA0YPQtdGCINGN0LrQt9C10LzQv9C70Y/RgCDQutC70LDRgdGB0LAge0BsaW5rIFNjUVJDb2RlRGlhbG9nQ29tcG9uZW50fS5cbiAgICAgKlxuICAgICAqIEBwYXJhbSB2Q2FyZFNlcnZpY2Ug0KHQtdGA0LLQuNGBINC00LvRjyDRgNCw0LHQvtGC0Ysg0YEgdkNhcmQuXG4gICAgICogQHBhcmFtIGNvbnRleHQg0JrQvtC90YLQtdC60YHRgiDQtNC40LDQu9C+0LPQvtCy0L7Qs9C+INC+0LrQvdCwLCDQsiDQutC+0YLQvtGA0L7QvCDQvtGC0LrRgNGL0YIg0LrQvtC80L/QvtC90LXQvdGCLlxuICAgICAqIEBwYXJhbSB0ZXJtaW5hbCDQn9GA0L7QstCw0LnQtNC10YAg0LTQsNC90L3Ri9GFINC+INGC0LXRgNC80LjQvdCw0LvQtS5cbiAgICAgKi9cbiAgICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgICAgIHByaXZhdGUgcmVhZG9ubHkgdkNhcmRTZXJ2aWNlOiBTY1ZDYXJkU2VydmljZSxcbiAgICAgICAgQEluamVjdChQT0xZTU9SUEhFVVNfQ09OVEVYVClcbiAgICAgICAgcHVibGljIHJlYWRvbmx5IGNvbnRleHQ6IFR1aURpYWxvZ0NvbnRleHQ8dm9pZCwgeyBxcmRhdGE6IHN0cmluZyB9PixcbiAgICAgICAgQEluamVjdChJU19SVU5OSU5HX09OX1RFUk1JTkFMKVxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgdGVybWluYWw6IFNjSVRlcm1pbmFsUHJvdmlkZXJcbiAgICApIHt9XG5cbiAgICAvKipcbiAgICAgKiDQktGL0L/QvtC70L3Rj9C10YIg0YHQutCw0YfQuNCy0LDQvdC40LUg0LPQtdC90LXRgNC40YDRg9C10LzQvtCz0L4gdkNhcmQg0YTQsNC50LvQsCDQutC+0L3RgtCw0LrRgtCwLlxuICAgICAqL1xuICAgIHB1YmxpYyBkb3dubG9hZFZDYXJkKCk6IHZvaWQge1xuICAgICAgICBpZiAoIXRoaXMudGVybWluYWwuaXNSdW5uaW5nT25UZXJtaW5hbCAmJiB0aGlzLmlzVkNhcmREYXRhKCkpIHtcbiAgICAgICAgICAgIHRoaXMudkNhcmRTZXJ2aWNlLmRvd25sb2FkVkNhcmQodGhpcy5jb250ZXh0LmRhdGEucXJkYXRhKTtcbiAgICAgICAgfVxuICAgIH1cblxuICAgIC8qKlxuICAgICAqINCf0YDQvtCy0LXRgNGP0LXRgiDRh9GC0L4g0LIg0LTQuNCw0LvQvtCz0L7QstC+0LUg0L7QutC90L4g0LHRi9C70Lgg0L/QtdGA0LXQtNCw0L3RiyDQtNCw0L3QvdGL0LUg0LIg0YTQvtGA0LzQsNGC0LUgYHZDYXJkYC5cbiAgICAgKi9cbiAgICBwdWJsaWMgaXNWQ2FyZERhdGEoKTogYm9vbGVhbiB7XG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSB1bmljb3JuL2JldHRlci1yZWdleFxuICAgICAgICByZXR1cm4gL0JFR0lOOlZDQVJEW1xcc1xcU10qRU5EOlZDQVJEL2kudGVzdCh0aGlzLmNvbnRleHQuZGF0YS5xcmRhdGEpO1xuICAgIH1cbn1cbiIsIjxwIGNsYXNzPVwiLW10LTIgbWItMyB0ZXh0LXR1aS10ZXh0LTAyXCI+e3sgdGVybWluYWwuaXNSdW5uaW5nT25UZXJtaW5hbCAmJiB0aGlzLmlzVkNhcmREYXRhKCkgPyAn0J4nIDogJ9Cd0LDQttC80LjRgtC1INC40LvQuCDQvicgfX3RgtGB0LrQsNC90LjRgNGD0LnRgtC1IFFSLdC60L7QtCDQstCw0YjQuNC8INC80L7QsdC40LvRjNC90YvQvCDRg9GB0YLRgNC+0LnRgdGC0LLQvtC8LjwvcD5cbjxxcmNvZGVcbiAgICAoY2xpY2spPVwiZG93bmxvYWRWQ2FyZCgpXCJcbiAgICBbbWFyZ2luXT1cIjBcIlxuICAgIFtxcmRhdGFdPVwidGhpcy5jb250ZXh0LmRhdGEucXJkYXRhXCJcbiAgICBbd2lkdGhdPVwiODAwXCJcbiAgICBlbGVtZW50VHlwZT1cImltZ1wiXG4gICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4+PC9xcmNvZGU+XG4iXX0=
54
+ }] }]; }, propDecorators: { terminalView: [{
55
+ type: HostBinding,
56
+ args: ['attr.data-terminal-view']
57
+ }] } });
58
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcXJjb2RlL3FyY29kZS1kaWFsb2cvc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jbGllbnQtdWkvcXJjb2RlL3FyY29kZS1kaWFsb2cvc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEYsT0FBTyxFQUFFLHNCQUFzQixFQUF1QyxNQUFNLHdCQUF3QixDQUFDO0FBRXJHLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLDBCQUEwQixDQUFDOzs7O0FBRWhFOztHQUVHO0FBT0gsTUFBTSxPQUFPLHVCQUF1QjtJQU9oQzs7Ozs7O09BTUc7SUFDSCxZQUNxQixZQUE0QixFQUU3QixPQUFtRCxFQUVuRCxRQUE2QjtRQUo1QixpQkFBWSxHQUFaLFlBQVksQ0FBZ0I7UUFFN0IsWUFBTyxHQUFQLE9BQU8sQ0FBNEM7UUFFbkQsYUFBUSxHQUFSLFFBQVEsQ0FBcUI7UUFsQmpEOztXQUVHO1FBRUssaUJBQVksR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDLG1CQUFtQixDQUFDO0lBZXRELENBQUM7SUFFSjs7T0FFRztJQUNJLGFBQWE7UUFDaEIsSUFBSSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsbUJBQW1CLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFO1lBQzFELElBQUksQ0FBQyxZQUFZLENBQUMsYUFBYSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzdEO0lBQ0wsQ0FBQztJQUVEOztPQUVHO0lBQ0ksV0FBVztRQUNkLGdEQUFnRDtRQUNoRCxPQUFPLDhCQUE4QixDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN6RSxDQUFDOztvSEFyQ1EsdUJBQXVCLGdEQWdCcEIsb0JBQW9CLGFBRXBCLHNCQUFzQjt3R0FsQnpCLHVCQUF1QixrSUNkcEMsaW5CQVNBOzJGREthLHVCQUF1QjtrQkFObkMsU0FBUzsrQkFDSSxrQkFBa0IsbUJBR1gsdUJBQXVCLENBQUMsTUFBTTs7MEJBa0IxQyxNQUFNOzJCQUFDLG9CQUFvQjs7MEJBRTNCLE1BQU07MkJBQUMsc0JBQXNCOzRDQWIxQixZQUFZO3NCQURuQixXQUFXO3VCQUFDLHlCQUF5QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElTX1JVTk5JTkdfT05fVEVSTUlOQUwsIFNjSVRlcm1pbmFsUHJvdmlkZXIsIFNjVkNhcmRTZXJ2aWNlIH0gZnJvbSAnQHNuYWJjZW50ci9jbGllbnQtY29yZSc7XG5pbXBvcnQgeyBUdWlEaWFsb2dDb250ZXh0IH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuaW1wb3J0IHsgUE9MWU1PUlBIRVVTX0NPTlRFWFQgfSBmcm9tICdAdGlua29mZi9uZy1wb2x5bW9ycGhldXMnO1xuXG4vKipcbiAqINCa0L7QvNC/0L7QvdC10L3RgiBRUiDQutC+0LTQsC5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdzYy1xcmNvZGUtZGlhbG9nJyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vc2MtcXJjb2RlLWRpYWxvZy5jb21wb25lbnQuc2NzcyddLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTY1FSQ29kZURpYWxvZ0NvbXBvbmVudCB7XG4gICAgLyoqXG4gICAgICog0KHQstC+0LnRgdGC0LLQviwg0L7RgiDQutC+0YLQvtGA0L7Qs9C+INC30LDQstC40YHQuNGCINC90LDQu9C40YfQuNC1INCw0YLRgNC40LHRg9GC0LAgYGRhdGEtdGVybWluYWwtdmlld2Ag0YMgYDpob3N0YCDQutC+0LzQv9C+0L3QtdC90YLQsC5cbiAgICAgKi9cbiAgICBASG9zdEJpbmRpbmcoJ2F0dHIuZGF0YS10ZXJtaW5hbC12aWV3JylcbiAgICBwcml2YXRlIHRlcm1pbmFsVmlldyA9IHRoaXMudGVybWluYWwuaXNSdW5uaW5nT25UZXJtaW5hbDtcblxuICAgIC8qKlxuICAgICAqINCY0L3QuNGG0LjQsNC70LjQt9C40YDRg9C10YIg0Y3QutC30LXQvNC/0LvRj9GAINC60LvQsNGB0YHQsCB7QGxpbmsgU2NRUkNvZGVEaWFsb2dDb21wb25lbnR9LlxuICAgICAqXG4gICAgICogQHBhcmFtIHZDYXJkU2VydmljZSDQodC10YDQstC40YEg0LTQu9GPINGA0LDQsdC+0YLRiyDRgSB2Q2FyZC5cbiAgICAgKiBAcGFyYW0gY29udGV4dCDQmtC+0L3RgtC10LrRgdGCINC00LjQsNC70L7Qs9C+0LLQvtCz0L4g0L7QutC90LAsINCyINC60L7RgtC+0YDQvtC8INC+0YLQutGA0YvRgiDQutC+0LzQv9C+0L3QtdC90YIuXG4gICAgICogQHBhcmFtIHRlcm1pbmFsINCf0YDQvtCy0LDQudC00LXRgCDQtNCw0L3QvdGL0YUg0L4g0YLQtdGA0LzQuNC90LDQu9C1LlxuICAgICAqL1xuICAgIHB1YmxpYyBjb25zdHJ1Y3RvcihcbiAgICAgICAgcHJpdmF0ZSByZWFkb25seSB2Q2FyZFNlcnZpY2U6IFNjVkNhcmRTZXJ2aWNlLFxuICAgICAgICBASW5qZWN0KFBPTFlNT1JQSEVVU19DT05URVhUKVxuICAgICAgICBwdWJsaWMgcmVhZG9ubHkgY29udGV4dDogVHVpRGlhbG9nQ29udGV4dDx2b2lkLCB7IHFyZGF0YTogc3RyaW5nIH0+LFxuICAgICAgICBASW5qZWN0KElTX1JVTk5JTkdfT05fVEVSTUlOQUwpXG4gICAgICAgIHB1YmxpYyByZWFkb25seSB0ZXJtaW5hbDogU2NJVGVybWluYWxQcm92aWRlclxuICAgICkge31cblxuICAgIC8qKlxuICAgICAqINCS0YvQv9C+0LvQvdGP0LXRgiDRgdC60LDRh9C40LLQsNC90LjQtSDQs9C10L3QtdGA0LjRgNGD0LXQvNC+0LPQviB2Q2FyZCDRhNCw0LnQu9CwINC60L7QvdGC0LDQutGC0LAuXG4gICAgICovXG4gICAgcHVibGljIGRvd25sb2FkVkNhcmQoKTogdm9pZCB7XG4gICAgICAgIGlmICghdGhpcy50ZXJtaW5hbC5pc1J1bm5pbmdPblRlcm1pbmFsICYmIHRoaXMuaXNWQ2FyZERhdGEoKSkge1xuICAgICAgICAgICAgdGhpcy52Q2FyZFNlcnZpY2UuZG93bmxvYWRWQ2FyZCh0aGlzLmNvbnRleHQuZGF0YS5xcmRhdGEpO1xuICAgICAgICB9XG4gICAgfVxuXG4gICAgLyoqXG4gICAgICog0J/RgNC+0LLQtdGA0Y/QtdGCINGH0YLQviDQsiDQtNC40LDQu9C+0LPQvtCy0L7QtSDQvtC60L3QviDQsdGL0LvQuCDQv9C10YDQtdC00LDQvdGLINC00LDQvdC90YvQtSDQsiDRhNC+0YDQvNCw0YLQtSBgdkNhcmRgLlxuICAgICAqL1xuICAgIHB1YmxpYyBpc1ZDYXJkRGF0YSgpOiBib29sZWFuIHtcbiAgICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHVuaWNvcm4vYmV0dGVyLXJlZ2V4XG4gICAgICAgIHJldHVybiAvQkVHSU46VkNBUkRbXFxzXFxTXSpFTkQ6VkNBUkQvaS50ZXN0KHRoaXMuY29udGV4dC5kYXRhLnFyZGF0YSk7XG4gICAgfVxufVxuIiwiPHAgY2xhc3M9XCItbXQtMiBtYi0zIHRleHQtdHVpLXRleHQtMDJcIj57eyAhdGVybWluYWwuaXNSdW5uaW5nT25UZXJtaW5hbCAmJiB0aGlzLmlzVkNhcmREYXRhKCkgPyAn0J3QsNC20LzQuNGC0LUg0LjQu9C4INC+JyA6ICfQnicgfX3RgtGB0LrQsNC90LjRgNGD0LnRgtC1IFFSLdC60L7QtCDQstCw0YjQuNC8INC80L7QsdC40LvRjNC90YvQvCDRg9GB0YLRgNC+0LnRgdGC0LLQvtC8LjwvcD5cbjxxcmNvZGVcbiAgICAoY2xpY2spPVwiZG93bmxvYWRWQ2FyZCgpXCJcbiAgICBbbWFyZ2luXT1cIjBcIlxuICAgIFtxcmRhdGFdPVwidGhpcy5jb250ZXh0LmRhdGEucXJkYXRhXCJcbiAgICBbd2lkdGhdPVwiODAwXCJcbiAgICBlbGVtZW50VHlwZT1cImltZ1wiXG4gICAgY2xhc3M9XCJjdXJzb3ItcG9pbnRlclwiXG4+PC9xcmNvZGU+XG4iXX0=
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { EventEmitter, Component, ChangeDetectionStrategy, Inject, Input, Output, SkipSelf, Directive, HostBinding, ContentChild, ViewChild, NgModule, ContentChildren, HostListener, Injectable, inject, ElementRef, Optional, ChangeDetectorRef, Self, InjectionToken, forwardRef } from '@angular/core';
2
+ import { EventEmitter, Component, ChangeDetectionStrategy, Inject, Input, Output, SkipSelf, inject, Directive, HostBinding, ContentChild, ViewChild, NgModule, ContentChildren, HostListener, Injectable, ElementRef, Optional, ChangeDetectorRef, Self, InjectionToken, forwardRef } from '@angular/core';
3
3
  import * as i1 from '@snabcentr/client-core';
4
4
  import { ScUserMetrikaGoalsEnum, ScISuggestionType, ScOpfList, ScWarehouseService, ScAuthService, SEARCH_TERM, ScImageHelper, SC_PATH_IMAGE_NOT_FOUND, IS_RUNNING_ON_TERMINAL, SC_URLS, TERMINAL_PROVIDERS, SEARCH_TERM_PROVIDERS, ScCatalogService, ScCartService, ScIconTypesEnum, ScUserService } from '@snabcentr/client-core';
5
5
  import * as i5 from 'rxjs';
@@ -7,7 +7,7 @@ import { Subject, map, filter, switchMap, tap, catchError, of, finalize, startWi
7
7
  import * as i2 from '@angular/common';
8
8
  import { CommonModule } from '@angular/common';
9
9
  import * as i4 from '@taiga-ui/core';
10
- import { TuiButtonModule, TuiModeModule, TuiDialogModule, TuiDialogService, TuiTextfieldControllerModule, TuiLabelModule, TuiErrorModule, TuiDataListModule, TuiLoaderModule, TuiNotificationModule, TuiLinkModule, TuiFormatPhonePipeModule, tuiFadeIn, TUI_MONTHS, TuiSvgModule, TuiHintModule, TuiFormatNumberPipeModule } from '@taiga-ui/core';
10
+ import { TUI_DATA_LIST_HOST, TuiButtonModule, TuiModeModule, TuiDialogModule, TuiDialogService, TuiTextfieldControllerModule, TuiLabelModule, TuiErrorModule, TuiDataListModule, TuiLoaderModule, TuiNotificationModule, TuiLinkModule, TuiFormatPhonePipeModule, tuiFadeIn, TUI_MONTHS, TuiSvgModule, TuiHintModule, TuiFormatNumberPipeModule } from '@taiga-ui/core';
11
11
  import { HttpErrorResponse } from '@angular/common/http';
12
12
  import * as i3 from '@angular/forms';
13
13
  import { FormGroupDirective, FormGroup, FormControl, Validators, NgControl, FormArray, FormsModule, ReactiveFormsModule } from '@angular/forms';
@@ -684,6 +684,12 @@ class ScSuggestionFieldComponent {
684
684
  * Перечисление типов подсказок.
685
685
  */
686
686
  this.suggestionType = ScISuggestionType;
687
+ /**
688
+ * Компонент обёртка выпадающего списка.
689
+ */
690
+ this.host = inject(TUI_DATA_LIST_HOST, {
691
+ optional: true,
692
+ });
687
693
  }
688
694
  /** @inheritDoc */
689
695
  ngOnInit() {
@@ -708,16 +714,16 @@ class ScSuggestionFieldComponent {
708
714
  * @param suggestion Объект подсказки.
709
715
  */
710
716
  onSelected(suggestion) {
711
- var _a, _b, _c, _d, _e;
717
+ var _a, _b, _c, _d, _e, _f;
712
718
  switch (this.type) {
713
719
  case ScISuggestionType.fio:
714
720
  if ('fio' in suggestion) {
715
- (_a = this.control.control) === null || _a === void 0 ? void 0 : _a.patchValue(suggestion.fio);
721
+ (_a = this.control.control) === null || _a === void 0 ? void 0 : _a.patchValue(suggestion.fio, { emitEvent: false });
716
722
  }
717
723
  break;
718
724
  case ScISuggestionType.address:
719
725
  if ('addressString' in suggestion) {
720
- (_b = this.control.control) === null || _b === void 0 ? void 0 : _b.patchValue(suggestion.addressString);
726
+ (_b = this.control.control) === null || _b === void 0 ? void 0 : _b.patchValue(suggestion.addressString, { emitEvent: false });
721
727
  }
722
728
  break;
723
729
  case ScISuggestionType.bank:
@@ -726,7 +732,7 @@ class ScSuggestionFieldComponent {
726
732
  bankName: suggestion.name,
727
733
  bic: suggestion.bic,
728
734
  correspondentAccount: suggestion.correspondentAccount,
729
- });
735
+ }, { emitEvent: false });
730
736
  }
731
737
  break;
732
738
  case ScISuggestionType.organization:
@@ -741,17 +747,19 @@ class ScSuggestionFieldComponent {
741
747
  legalAddress: suggestion.legalAddress,
742
748
  postalAddress: suggestion.postalAddress,
743
749
  actualAddress: suggestion.actualAddress,
744
- });
750
+ }, { emitEvent: false });
745
751
  }
746
752
  break;
747
753
  case ScISuggestionType.email:
748
754
  if ('email' in suggestion) {
749
- (_e = this.control.control) === null || _e === void 0 ? void 0 : _e.patchValue(suggestion.email);
755
+ (_e = this.control.control) === null || _e === void 0 ? void 0 : _e.patchValue(suggestion.email, { emitEvent: false });
750
756
  }
751
757
  break;
752
758
  default:
753
759
  break;
754
760
  }
761
+ // Дёргаем внутренний обработчик выбора элемента выпадающего списка.
762
+ (_f = this.host) === null || _f === void 0 ? void 0 : _f.handleOption(this.control.value);
755
763
  this.selectedClick.emit(suggestion);
756
764
  }
757
765
  }
@@ -1716,6 +1724,10 @@ class ScQRCodeDialogComponent {
1716
1724
  this.vCardService = vCardService;
1717
1725
  this.context = context;
1718
1726
  this.terminal = terminal;
1727
+ /**
1728
+ * Свойство, от которого зависит наличие атрибута `data-terminal-view` у `:host` компонента.
1729
+ */
1730
+ this.terminalView = this.terminal.isRunningOnTerminal;
1719
1731
  }
1720
1732
  /**
1721
1733
  * Выполняет скачивание генерируемого vCard файла контакта.
@@ -1734,10 +1746,10 @@ class ScQRCodeDialogComponent {
1734
1746
  }
1735
1747
  }
1736
1748
  ScQRCodeDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScQRCodeDialogComponent, deps: [{ token: i1.ScVCardService }, { token: POLYMORPHEUS_CONTEXT }, { token: IS_RUNNING_ON_TERMINAL }], target: i0.ɵɵFactoryTarget.Component });
1737
- ScQRCodeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScQRCodeDialogComponent, selector: "sc-qrcode-dialog", ngImport: i0, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ terminal.isRunningOnTerminal && this.isVCardData() ? '\u041E' : '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"], dependencies: [{ kind: "component", type: i2$2.QRCodeComponent, selector: "qrcode", inputs: ["allowEmptyString", "colorDark", "colorLight", "cssClass", "elementType", "errorCorrectionLevel", "imageSrc", "imageHeight", "imageWidth", "margin", "qrdata", "scale", "version", "width", "alt", "ariaLabel", "title"], outputs: ["qrCodeURL"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
1749
+ ScQRCodeDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScQRCodeDialogComponent, selector: "sc-qrcode-dialog", host: { properties: { "attr.data-terminal-view": "this.terminalView" } }, ngImport: i0, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ !terminal.isRunningOnTerminal && this.isVCardData() ? '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' : '\u041E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"], dependencies: [{ kind: "component", type: i2$2.QRCodeComponent, selector: "qrcode", inputs: ["allowEmptyString", "colorDark", "colorLight", "cssClass", "elementType", "errorCorrectionLevel", "imageSrc", "imageHeight", "imageWidth", "margin", "qrdata", "scale", "version", "width", "alt", "ariaLabel", "title"], outputs: ["qrCodeURL"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
1738
1750
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScQRCodeDialogComponent, decorators: [{
1739
1751
  type: Component,
1740
- args: [{ selector: 'sc-qrcode-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ terminal.isRunningOnTerminal && this.isVCardData() ? '\u041E' : '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"] }]
1752
+ args: [{ selector: 'sc-qrcode-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<p class=\"-mt-2 mb-3 text-tui-text-02\">{{ !terminal.isRunningOnTerminal && this.isVCardData() ? '\u041D\u0430\u0436\u043C\u0438\u0442\u0435 \u0438\u043B\u0438 \u043E' : '\u041E' }}\u0442\u0441\u043A\u0430\u043D\u0438\u0440\u0443\u0439\u0442\u0435 QR-\u043A\u043E\u0434 \u0432\u0430\u0448\u0438\u043C \u043C\u043E\u0431\u0438\u043B\u044C\u043D\u044B\u043C \u0443\u0441\u0442\u0440\u043E\u0439\u0441\u0442\u0432\u043E\u043C.</p>\n<qrcode\n (click)=\"downloadVCard()\"\n [margin]=\"0\"\n [qrdata]=\"this.context.data.qrdata\"\n [width]=\"800\"\n elementType=\"img\"\n class=\"cursor-pointer\"\n></qrcode>\n", styles: ["::ng-deep tui-dialog:has([data-terminal-view=true]){width:21rem!important}::ng-deep tui-dialog:has([data-terminal-view=true]) .t-heading{margin-bottom:.5rem!important;font:var(--tui-font-heading-6)!important}\n"] }]
1741
1753
  }], ctorParameters: function () {
1742
1754
  return [{ type: i1.ScVCardService }, { type: undefined, decorators: [{
1743
1755
  type: Inject,
@@ -1746,7 +1758,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
1746
1758
  type: Inject,
1747
1759
  args: [IS_RUNNING_ON_TERMINAL]
1748
1760
  }] }];
1749
- } });
1761
+ }, propDecorators: { terminalView: [{
1762
+ type: HostBinding,
1763
+ args: ['attr.data-terminal-view']
1764
+ }] } });
1750
1765
 
1751
1766
  /**
1752
1767
  * Модуль QR кода.