@snabcentr/client-ui 0.28.3 → 0.30.0
Sign up to get free protection for your applications and to get access to all the features.
- package/contacts/add-contact-dialog/sc-add-contact-dialog.component.d.ts +8 -3
- package/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.d.ts +9 -4
- package/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.d.ts +8 -3
- package/esm2020/contacts/add-contact-dialog/sc-add-contact-dialog.component.mjs +13 -4
- package/esm2020/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.mjs +13 -5
- package/esm2020/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.mjs +13 -5
- package/esm2020/user/update-user-info-dialog/sc-update-user-info-dialog.component.mjs +27 -17
- package/esm2020/user/user-phone-approve-dialog/sc-user-phone-approve-dialog.component.mjs +13 -4
- package/fesm2015/snabcentr-client-ui.mjs +66 -24
- package/fesm2015/snabcentr-client-ui.mjs.map +1 -1
- package/fesm2020/snabcentr-client-ui.mjs +66 -24
- package/fesm2020/snabcentr-client-ui.mjs.map +1 -1
- package/package.json +2 -2
- package/user/update-user-info-dialog/sc-update-user-info-dialog.component.d.ts +11 -7
- package/user/user-phone-approve-dialog/sc-user-phone-approve-dialog.component.d.ts +9 -4
@@ -1,14 +1,16 @@
|
|
1
|
+
import { AfterViewInit } from '@angular/core';
|
1
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
2
|
-
import { ScContactsService, ScConvertersService, ScIContactBase, ScIContactOnDataCreate, ScIContactWithRelations } from '@snabcentr/client-core';
|
3
|
+
import { ScContactsService, ScConvertersService, ScIContactBase, ScIContactOnDataCreate, ScIContactWithRelations, ScUserMetrikaService } from '@snabcentr/client-core';
|
3
4
|
import { TuiDialogContext } from '@taiga-ui/core';
|
4
5
|
import { Observable, Subject } from 'rxjs';
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
/**
|
7
8
|
* Компонент формы создания нового контактного лица.
|
8
9
|
*/
|
9
|
-
export declare class ScAddContactDialogComponent {
|
10
|
+
export declare class ScAddContactDialogComponent implements AfterViewInit {
|
10
11
|
private readonly contactsService;
|
11
12
|
readonly convertersService: ScConvertersService;
|
13
|
+
private readonly userMetrikaService;
|
12
14
|
readonly context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>;
|
13
15
|
/**
|
14
16
|
* Группа с полями контактного лица.
|
@@ -36,9 +38,12 @@ export declare class ScAddContactDialogComponent {
|
|
36
38
|
*
|
37
39
|
* @param contactsService Сервис для работы с контактными лицами.
|
38
40
|
* @param convertersService Сервис конвертации данных.
|
41
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
39
42
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
40
43
|
*/
|
41
|
-
constructor(contactsService: ScContactsService, convertersService: ScConvertersService, context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>);
|
44
|
+
constructor(contactsService: ScContactsService, convertersService: ScConvertersService, userMetrikaService: ScUserMetrikaService, context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>);
|
45
|
+
/** @inheritdoc */
|
46
|
+
ngAfterViewInit(): void;
|
42
47
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddContactDialogComponent, never>;
|
43
48
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScAddContactDialogComponent, "sc-add-contact-dialog", never, {}, {}, never, never, false>;
|
44
49
|
}
|
@@ -1,15 +1,17 @@
|
|
1
|
+
import { AfterViewInit } from '@angular/core';
|
1
2
|
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
2
|
-
import { ScContragent, ScContragentService, ScConvertersService, ScICountry, ScICurrency, ScIReferencesTypes, ScISalesDirection, ScLocationsService, ScOpfList, ScReferencesService } from '@snabcentr/client-core';
|
3
|
+
import { ScContragent, ScContragentService, ScConvertersService, ScICountry, ScICurrency, ScIReferencesTypes, ScISalesDirection, ScLocationsService, ScOpfList, ScReferencesService, ScUserMetrikaService } from '@snabcentr/client-core';
|
3
4
|
import { TuiDialogContext } from '@taiga-ui/core';
|
4
5
|
import { Observable, Subject } from 'rxjs';
|
5
6
|
import * as i0 from "@angular/core";
|
6
7
|
/**
|
7
8
|
* Компотен добавления контрагента.
|
8
9
|
*/
|
9
|
-
export declare class ScAddContragentDialogComponent {
|
10
|
+
export declare class ScAddContragentDialogComponent implements AfterViewInit {
|
10
11
|
private readonly referencesService;
|
11
12
|
private readonly contragentService;
|
12
13
|
private readonly convertersService;
|
14
|
+
private readonly userMetrikaService;
|
13
15
|
private readonly locationsService;
|
14
16
|
readonly context: TuiDialogContext<ScContragent, void>;
|
15
17
|
/**
|
@@ -44,10 +46,13 @@ export declare class ScAddContragentDialogComponent {
|
|
44
46
|
* @param referencesService Сервис справочников.
|
45
47
|
* @param contragentService Сервис работы с контрагентами.
|
46
48
|
* @param convertersService Сервис конвертации данных.
|
49
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
47
50
|
* @param locationsService
|
48
51
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
49
52
|
*/
|
50
|
-
constructor(referencesService: ScReferencesService, contragentService: ScContragentService, convertersService: ScConvertersService, locationsService: ScLocationsService, context: TuiDialogContext<ScContragent, void>);
|
53
|
+
constructor(referencesService: ScReferencesService, contragentService: ScContragentService, convertersService: ScConvertersService, userMetrikaService: ScUserMetrikaService, locationsService: ScLocationsService, context: TuiDialogContext<ScContragent, void>);
|
54
|
+
/** @inheritdoc */
|
55
|
+
ngAfterViewInit(): void;
|
51
56
|
/**
|
52
57
|
* Текущий выбранный ОПФ.
|
53
58
|
*/
|
@@ -145,6 +150,6 @@ export declare class ScAddContragentDialogComponent {
|
|
145
150
|
* @param index Индекс контактного лица.
|
146
151
|
*/
|
147
152
|
removeContactGroup(index: number): void;
|
148
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddContragentDialogComponent, [null, null, null, null, { optional: true; }]>;
|
153
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddContragentDialogComponent, [null, null, null, null, null, { optional: true; }]>;
|
149
154
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScAddContragentDialogComponent, "sc-add-contragent-dialog", never, {}, {}, never, never, false>;
|
150
155
|
}
|
package/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.d.ts
CHANGED
@@ -1,5 +1,6 @@
|
|
1
|
+
import { AfterViewInit } from '@angular/core';
|
1
2
|
import { FormControl, FormGroup } from '@angular/forms';
|
2
|
-
import { ScConvertersService, ScDeliveryAddressService, ScISuggestionType } from '@snabcentr/client-core';
|
3
|
+
import { ScConvertersService, ScDeliveryAddressService, ScISuggestionType, ScUserMetrikaService } from '@snabcentr/client-core';
|
3
4
|
import { TuiDialogContext } from '@taiga-ui/core';
|
4
5
|
import { Observable, Subject } from 'rxjs';
|
5
6
|
import * as i0 from "@angular/core";
|
@@ -8,8 +9,9 @@ import * as i0 from "@angular/core";
|
|
8
9
|
*
|
9
10
|
* TODO: TASK[8813] Добавить карту, и поведение выбора адреса доставки через карту. При этом вынести форму в отдельный компонент AddDeliveryAddressForm или submit логику в директиву.
|
10
11
|
*/
|
11
|
-
export declare class ScAddDeliveryAddressDialogComponent {
|
12
|
+
export declare class ScAddDeliveryAddressDialogComponent implements AfterViewInit {
|
12
13
|
private readonly deliveryAddressService;
|
14
|
+
private readonly userMetrikaService;
|
13
15
|
readonly context: TuiDialogContext<void, void>;
|
14
16
|
private readonly convertersService;
|
15
17
|
/**
|
@@ -48,10 +50,13 @@ export declare class ScAddDeliveryAddressDialogComponent {
|
|
48
50
|
* Инициализирует экземпляр класса {@link ScAddDeliveryAddressDialogComponent}.
|
49
51
|
*
|
50
52
|
* @param deliveryAddressService Сервис работы с адресами доставки.
|
53
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
51
54
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
52
55
|
* @param convertersService Сервис конвертации данных.
|
53
56
|
*/
|
54
|
-
constructor(deliveryAddressService: ScDeliveryAddressService, context: TuiDialogContext<void, void>, convertersService: ScConvertersService);
|
57
|
+
constructor(deliveryAddressService: ScDeliveryAddressService, userMetrikaService: ScUserMetrikaService, context: TuiDialogContext<void, void>, convertersService: ScConvertersService);
|
58
|
+
/** @inheritdoc */
|
59
|
+
ngAfterViewInit(): void;
|
55
60
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddDeliveryAddressDialogComponent, never>;
|
56
61
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScAddDeliveryAddressDialogComponent, "sc-add-delivery-address-dialog", never, {}, {}, never, never, false>;
|
57
62
|
}
|
@@ -2,6 +2,7 @@
|
|
2
2
|
import { HttpErrorResponse } from '@angular/common/http';
|
3
3
|
import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
|
4
4
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
5
|
+
import { ScUserMetrikaGoalsEnum, } from '@snabcentr/client-core';
|
5
6
|
import { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';
|
6
7
|
import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
|
7
8
|
import { catchError, filter, map, of, share, startWith, Subject, switchMap, tap } from 'rxjs';
|
@@ -20,11 +21,13 @@ export class ScAddContactDialogComponent {
|
|
20
21
|
*
|
21
22
|
* @param contactsService Сервис для работы с контактными лицами.
|
22
23
|
* @param convertersService Сервис конвертации данных.
|
24
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
23
25
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
24
26
|
*/
|
25
|
-
constructor(contactsService, convertersService, context) {
|
27
|
+
constructor(contactsService, convertersService, userMetrikaService, context) {
|
26
28
|
this.contactsService = contactsService;
|
27
29
|
this.convertersService = convertersService;
|
30
|
+
this.userMetrikaService = userMetrikaService;
|
28
31
|
this.context = context;
|
29
32
|
/**
|
30
33
|
* Группа с полями контактного лица.
|
@@ -66,14 +69,20 @@ export class ScAddContactDialogComponent {
|
|
66
69
|
*/
|
67
70
|
this.loading$ = this.request$.pipe(map(tuiIsFalsy));
|
68
71
|
}
|
72
|
+
/** @inheritdoc */
|
73
|
+
ngAfterViewInit() {
|
74
|
+
this.userMetrikaService.emitUserMetrikaEvent({
|
75
|
+
target: ScUserMetrikaGoalsEnum.userProfileContactAddShow,
|
76
|
+
});
|
77
|
+
}
|
69
78
|
}
|
70
|
-
ScAddContactDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContactDialogComponent, deps: [{ token: i1.ScContactsService }, { token: i1.ScConvertersService }, { token: POLYMORPHEUS_CONTEXT }], target: i0.ɵɵFactoryTarget.Component });
|
79
|
+
ScAddContactDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContactDialogComponent, deps: [{ token: i1.ScContactsService }, { token: i1.ScConvertersService }, { token: i1.ScUserMetrikaService }, { token: POLYMORPHEUS_CONTEXT }], target: i0.ɵɵFactoryTarget.Component });
|
71
80
|
ScAddContactDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScAddContactDialogComponent, selector: "sc-add-contact-dialog", ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-3\">\n <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n <div class=\"flex gap-4 justify-center\">\n <button tuiButton (click)=\"context.$implicit.complete()\" type=\"button\" icon=\"tuiIconXLarge\" appearance=\"secondary\">\u041E\u0442\u043C\u0435\u043D\u0430</button>\n <button tuiButton tuiMode=\"onLight\" [disabled]=\"form.invalid\" [showLoader]=\"!!(loading$ | async)\" type=\"submit\" icon=\"scIconSave\">\u0421\u043E\u0445\u0440\u0430\u043D\u0438\u0442\u044C</button>\n </div>\n</form>\n", dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i3.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "component", type: i4.ScNewContactFormComponent, selector: "sc-new-contact-form", inputs: ["form"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
72
81
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContactDialogComponent, decorators: [{
|
73
82
|
type: Component,
|
74
83
|
args: [{ selector: 'sc-add-contact-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-3\">\n <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n <div class=\"flex gap-4 justify-center\">\n <button tuiButton (click)=\"context.$implicit.complete()\" type=\"button\" icon=\"tuiIconXLarge\" appearance=\"secondary\">\u041E\u0442\u043C\u0435\u043D\u0430</button>\n <button tuiButton tuiMode=\"onLight\" [disabled]=\"form.invalid\" [showLoader]=\"!!(loading$ | async)\" type=\"submit\" icon=\"scIconSave\">\u0421\u043E\u0445\u0440\u0430\u043D\u0438\u0442\u044C</button>\n </div>\n</form>\n" }]
|
75
|
-
}], ctorParameters: function () { return [{ type: i1.ScContactsService }, { type: i1.ScConvertersService }, { type: undefined, decorators: [{
|
84
|
+
}], ctorParameters: function () { return [{ type: i1.ScContactsService }, { type: i1.ScConvertersService }, { type: i1.ScUserMetrikaService }, { type: undefined, decorators: [{
|
76
85
|
type: Inject,
|
77
86
|
args: [POLYMORPHEUS_CONTEXT]
|
78
87
|
}] }]; } });
|
79
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contact-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.ts","../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ScContactsService, ScConvertersService, ScIBankAccount, ScIContactBase, ScIContactOnDataCreate, ScIContactWithRelations } from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\n\n/**\n * Компонент формы создания нового контактного лица.\n */\n@Component({\n    selector: 'sc-add-contact-dialog',\n    templateUrl: './sc-add-contact-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContactDialogComponent {\n    /**\n     * Группа с полями контактного лица.\n     */\n    public form = new FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }>({\n        name: new FormControl<string | null>(null, Validators.required),\n        phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n        email: new FormControl<string | null>(null, Validators.email),\n        position: new FormControl<string | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контактного лица.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIContactOnDataCreate => this.form.valid),\n        map((value) => this.convertersService.removeNull<ScIContactOnDataCreate>({ ...value, ...this.context.data })),\n        switchMap((data) => {\n            return this.contactsService.createContact$(data).pipe(\n                tap((contact) => {\n                    this.context.completeWith(contact);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContactDialogComponent}.\n     *\n     * @param contactsService Сервис для работы с контактными лицами.\n     * @param convertersService Сервис конвертации данных.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contactsService: ScContactsService,\n        public readonly convertersService: ScConvertersService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>\n    ) {}\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-3\">\n    <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n    <div class=\"flex gap-4 justify-center\">\n        <button tuiButton (click)=\"context.$implicit.complete()\" type=\"button\" icon=\"tuiIconXLarge\" appearance=\"secondary\">Отмена</button>\n        <button tuiButton tuiMode=\"onLight\" [disabled]=\"form.invalid\" [showLoader]=\"!!(loading$ | async)\" type=\"submit\" icon=\"scIconSave\">Сохранить</button>\n    </div>\n</form>\n"]}
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contact-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.ts","../../../../../projects/client-ui/contacts/add-contact-dialog/sc-add-contact-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-restricted-syntax,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    ScContactsService,\n    ScConvertersService,\n    ScIBankAccount,\n    ScIContactBase,\n    ScIContactOnDataCreate,\n    ScIContactWithRelations,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\n\n/**\n * Компонент формы создания нового контактного лица.\n */\n@Component({\n    selector: 'sc-add-contact-dialog',\n    templateUrl: './sc-add-contact-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddContactDialogComponent implements AfterViewInit {\n    /**\n     * Группа с полями контактного лица.\n     */\n    public form = new FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }>({\n        name: new FormControl<string | null>(null, Validators.required),\n        phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n        email: new FormControl<string | null>(null, Validators.email),\n        position: new FormControl<string | null>(null, Validators.required),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контактного лица.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value),\n        filter((value): value is ScIContactOnDataCreate => this.form.valid),\n        map((value) => this.convertersService.removeNull<ScIContactOnDataCreate>({ ...value, ...this.context.data })),\n        switchMap((data) => {\n            return this.contactsService.createContact$(data).pipe(\n                tap((contact) => {\n                    this.context.completeWith(contact);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n                    }\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContactDialogComponent}.\n     *\n     * @param contactsService Сервис для работы с контактными лицами.\n     * @param convertersService Сервис конвертации данных.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly contactsService: ScContactsService,\n        public readonly convertersService: ScConvertersService,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScIContactWithRelations, Omit<ScIContactOnDataCreate, keyof ScIContactBase>>\n    ) {}\n\n    /** @inheritdoc */\n    public ngAfterViewInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.userProfileContactAddShow,\n        });\n    }\n}\n","<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-3\">\n    <sc-new-contact-form [form]=\"form\"></sc-new-contact-form>\n    <div class=\"flex gap-4 justify-center\">\n        <button tuiButton (click)=\"context.$implicit.complete()\" type=\"button\" icon=\"tuiIconXLarge\" appearance=\"secondary\">Отмена</button>\n        <button tuiButton tuiMode=\"onLight\" [disabled]=\"form.invalid\" [showLoader]=\"!!(loading$ | async)\" type=\"submit\" icon=\"scIconSave\">Сохранить</button>\n    </div>\n</form>\n"]}
|
@@ -4,7 +4,7 @@ import { HttpErrorResponse } from '@angular/common/http';
|
|
4
4
|
import { ChangeDetectionStrategy, Component, Inject, Optional } from '@angular/core';
|
5
5
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
6
6
|
import { UntilDestroy } from '@ngneat/until-destroy';
|
7
|
-
import { ScOpfList, } from '@snabcentr/client-core';
|
7
|
+
import { ScOpfList, ScUserMetrikaGoalsEnum, } from '@snabcentr/client-core';
|
8
8
|
import { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';
|
9
9
|
import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
|
10
10
|
import { catchError, filter, map, of, share, startWith, Subject, switchMap, tap } from 'rxjs';
|
@@ -28,13 +28,15 @@ let ScAddContragentDialogComponent = class ScAddContragentDialogComponent {
|
|
28
28
|
* @param referencesService Сервис справочников.
|
29
29
|
* @param contragentService Сервис работы с контрагентами.
|
30
30
|
* @param convertersService Сервис конвертации данных.
|
31
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
31
32
|
* @param locationsService
|
32
33
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
33
34
|
*/
|
34
|
-
constructor(referencesService, contragentService, convertersService, locationsService, context) {
|
35
|
+
constructor(referencesService, contragentService, convertersService, userMetrikaService, locationsService, context) {
|
35
36
|
this.referencesService = referencesService;
|
36
37
|
this.contragentService = contragentService;
|
37
38
|
this.convertersService = convertersService;
|
39
|
+
this.userMetrikaService = userMetrikaService;
|
38
40
|
this.locationsService = locationsService;
|
39
41
|
this.context = context;
|
40
42
|
/**
|
@@ -84,6 +86,12 @@ let ScAddContragentDialogComponent = class ScAddContragentDialogComponent {
|
|
84
86
|
*/
|
85
87
|
this.loading$ = this.request$.pipe(map(tuiIsFalsy));
|
86
88
|
}
|
89
|
+
/** @inheritdoc */
|
90
|
+
ngAfterViewInit() {
|
91
|
+
this.userMetrikaService.emitUserMetrikaEvent({
|
92
|
+
target: ScUserMetrikaGoalsEnum.userProfileContragentAddShow,
|
93
|
+
});
|
94
|
+
}
|
87
95
|
/**
|
88
96
|
* Текущий выбранный ОПФ.
|
89
97
|
*/
|
@@ -242,7 +250,7 @@ let ScAddContragentDialogComponent = class ScAddContragentDialogComponent {
|
|
242
250
|
this.contacts.removeAt(index);
|
243
251
|
}
|
244
252
|
};
|
245
|
-
ScAddContragentDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContragentDialogComponent, deps: [{ token: i1.ScReferencesService }, { token: i1.ScContragentService }, { token: i1.ScConvertersService }, { token: i1.ScLocationsService }, { token: POLYMORPHEUS_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
253
|
+
ScAddContragentDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContragentDialogComponent, deps: [{ token: i1.ScReferencesService }, { token: i1.ScContragentService }, { token: i1.ScConvertersService }, { token: i1.ScUserMetrikaService }, { token: i1.ScLocationsService }, { token: POLYMORPHEUS_CONTEXT, optional: true }], target: i0.ɵɵFactoryTarget.Component });
|
246
254
|
ScAddContragentDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScAddContragentDialogComponent, selector: "sc-add-contragent-dialog", ngImport: i0, template: "<form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit.next()\"\n class=\"flex flex-col gap-4\"\n>\n <tui-elastic-container>\n <sc-new-contragent-form [class.!hidden]=\"stepIndex !== 0\"></sc-new-contragent-form>\n\n <div [class.!hidden]=\"stepIndex !== 1\">\n <div\n *ngIf=\"contacts\"\n class=\"flex flex-col gap-5 pb-1\"\n >\n <p class=\"text-lg font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u044B</p>\n <div\n *ngFor=\"let contact of contacts.controls; let index = index; let count = count; let last = last\"\n class=\"flex flex-col gap-3\"\n >\n <div class=\"flex h-10 items-center justify-between\">\n <p class=\"font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442 \u2116{{ index + 1 }}:</p>\n <button\n *ngIf=\"count - 1\"\n tuiIconButton\n appearance=\"secondary\"\n (click)=\"removeContactGroup(index)\"\n icon=\"tuiIconTrash2Large\"\n ></button>\n </div>\n <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n <hr\n *ngIf=\"!last\"\n class=\"h-px w-full bg-tui-base-04\"\n />\n </div>\n <button\n tuiButton\n icon=\"tuiIconPlusLarge\"\n [appearance]=\"'secondary'\"\n (click)=\"addContactGroup()\"\n type=\"button\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043A\u043E\u043D\u0442\u0430\u043A\u0442\n </button>\n </div>\n </div>\n\n <div [class.!hidden]=\"stepIndex !== 2\">\n <div\n *ngIf=\"bankAccounts\"\n class=\"flex flex-col gap-5 pb-1\"\n >\n <p class=\"text-lg font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</p>\n <div\n *ngFor=\"let bankAccount of bankAccounts.controls; let index = index; let count = count; let last = last\"\n class=\"flex flex-col gap-3\"\n >\n <div class=\"flex h-12 items-center justify-between\">\n <p class=\"font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B \u2116{{ index + 1 }}:</p>\n <button\n *ngIf=\"count - 1\"\n tuiIconButton\n appearance=\"secondary\"\n (click)=\"removeBankAccountGroup(index)\"\n icon=\"tuiIconTrash2Large\"\n ></button>\n </div>\n <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n <hr\n *ngIf=\"!last\"\n class=\"h-px w-full bg-tui-base-04\"\n />\n </div>\n <button\n tuiButton\n icon=\"tuiIconPlusLarge\"\n [appearance]=\"'secondary'\"\n (click)=\"addBankAccountGroup()\"\n type=\"button\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n </button>\n </div>\n </div>\n </tui-elastic-container>\n <div class=\"flex justify-center gap-2\">\n <button\n *ngIf=\"stepIndex > 0\"\n tuiButton\n appearance=\"secondary\"\n type=\"button\"\n (click)=\"stepIndex = (stepIndex - 1) % 3\"\n >\n \u041D\u0430\u0437\u0430\u0434\n </button>\n <button\n *ngIf=\"stepIndex === 0\"\n tuiButton\n (click)=\"context.$implicit.complete()\"\n type=\"button\"\n appearance=\"secondary\"\n >\n \u041E\u0442\u043C\u0435\u043D\u0430\n </button>\n <button\n *ngIf=\"stepIndex === 2 || (stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']); else nextIndexBtn\"\n tuiButton\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n class=\"self-center\"\n >\n \u0421\u043E\u0437\u0434\u0430\u0442\u044C\n </button>\n <ng-template #nextIndexBtn>\n <button\n tuiButton\n [disabled]=\"!canNextStep()\"\n type=\"button\"\n (click)=\"stepIndex = (stepIndex + 1) % 3\"\n >\n \u0414\u0430\u043B\u0435\u0435\n </button>\n </ng-template>\n </div>\n</form>\n", styles: ["tui-carousel{--tui-carousel-padding: .5rem}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "component", type: i5.ScNewContactFormComponent, selector: "sc-new-contact-form", inputs: ["form"] }, { kind: "component", type: i6.TuiElasticContainerComponent, selector: "tui-elastic-container" }, { kind: "component", type: i7.ScNewContragentBankAccountsFormComponent, selector: "sc-new-contragent-bank-account-form", inputs: ["form"] }, { kind: "component", type: i8.ScNewContragentFormComponent, selector: "sc-new-contragent-form" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
247
255
|
ScAddContragentDialogComponent = __decorate([
|
248
256
|
UntilDestroy({ checkProperties: true })
|
@@ -251,10 +259,10 @@ export { ScAddContragentDialogComponent };
|
|
251
259
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddContragentDialogComponent, decorators: [{
|
252
260
|
type: Component,
|
253
261
|
args: [{ selector: 'sc-add-contragent-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit.next()\"\n class=\"flex flex-col gap-4\"\n>\n <tui-elastic-container>\n <sc-new-contragent-form [class.!hidden]=\"stepIndex !== 0\"></sc-new-contragent-form>\n\n <div [class.!hidden]=\"stepIndex !== 1\">\n <div\n *ngIf=\"contacts\"\n class=\"flex flex-col gap-5 pb-1\"\n >\n <p class=\"text-lg font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u044B</p>\n <div\n *ngFor=\"let contact of contacts.controls; let index = index; let count = count; let last = last\"\n class=\"flex flex-col gap-3\"\n >\n <div class=\"flex h-10 items-center justify-between\">\n <p class=\"font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442 \u2116{{ index + 1 }}:</p>\n <button\n *ngIf=\"count - 1\"\n tuiIconButton\n appearance=\"secondary\"\n (click)=\"removeContactGroup(index)\"\n icon=\"tuiIconTrash2Large\"\n ></button>\n </div>\n <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n <hr\n *ngIf=\"!last\"\n class=\"h-px w-full bg-tui-base-04\"\n />\n </div>\n <button\n tuiButton\n icon=\"tuiIconPlusLarge\"\n [appearance]=\"'secondary'\"\n (click)=\"addContactGroup()\"\n type=\"button\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u043A\u043E\u043D\u0442\u0430\u043A\u0442\n </button>\n </div>\n </div>\n\n <div [class.!hidden]=\"stepIndex !== 2\">\n <div\n *ngIf=\"bankAccounts\"\n class=\"flex flex-col gap-5 pb-1\"\n >\n <p class=\"text-lg font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B</p>\n <div\n *ngFor=\"let bankAccount of bankAccounts.controls; let index = index; let count = count; let last = last\"\n class=\"flex flex-col gap-3\"\n >\n <div class=\"flex h-12 items-center justify-between\">\n <p class=\"font-bold\">\u0411\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B \u2116{{ index + 1 }}:</p>\n <button\n *ngIf=\"count - 1\"\n tuiIconButton\n appearance=\"secondary\"\n (click)=\"removeBankAccountGroup(index)\"\n icon=\"tuiIconTrash2Large\"\n ></button>\n </div>\n <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n <hr\n *ngIf=\"!last\"\n class=\"h-px w-full bg-tui-base-04\"\n />\n </div>\n <button\n tuiButton\n icon=\"tuiIconPlusLarge\"\n [appearance]=\"'secondary'\"\n (click)=\"addBankAccountGroup()\"\n type=\"button\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C \u0431\u0430\u043D\u043A\u043E\u0432\u0441\u043A\u0438\u0435 \u0440\u0435\u043A\u0432\u0438\u0437\u0438\u0442\u044B\n </button>\n </div>\n </div>\n </tui-elastic-container>\n <div class=\"flex justify-center gap-2\">\n <button\n *ngIf=\"stepIndex > 0\"\n tuiButton\n appearance=\"secondary\"\n type=\"button\"\n (click)=\"stepIndex = (stepIndex - 1) % 3\"\n >\n \u041D\u0430\u0437\u0430\u0434\n </button>\n <button\n *ngIf=\"stepIndex === 0\"\n tuiButton\n (click)=\"context.$implicit.complete()\"\n type=\"button\"\n appearance=\"secondary\"\n >\n \u041E\u0442\u043C\u0435\u043D\u0430\n </button>\n <button\n *ngIf=\"stepIndex === 2 || (stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']); else nextIndexBtn\"\n tuiButton\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n class=\"self-center\"\n >\n \u0421\u043E\u0437\u0434\u0430\u0442\u044C\n </button>\n <ng-template #nextIndexBtn>\n <button\n tuiButton\n [disabled]=\"!canNextStep()\"\n type=\"button\"\n (click)=\"stepIndex = (stepIndex + 1) % 3\"\n >\n \u0414\u0430\u043B\u0435\u0435\n </button>\n </ng-template>\n </div>\n</form>\n", styles: ["tui-carousel{--tui-carousel-padding: .5rem}\n"] }]
|
254
|
-
}], ctorParameters: function () { return [{ type: i1.ScReferencesService }, { type: i1.ScContragentService }, { type: i1.ScConvertersService }, { type: i1.ScLocationsService }, { type: undefined, decorators: [{
|
262
|
+
}], ctorParameters: function () { return [{ type: i1.ScReferencesService }, { type: i1.ScContragentService }, { type: i1.ScConvertersService }, { type: i1.ScUserMetrikaService }, { type: i1.ScLocationsService }, { type: undefined, decorators: [{
|
255
263
|
type: Optional
|
256
264
|
}, {
|
257
265
|
type: Inject,
|
258
266
|
args: [POLYMORPHEUS_CONTEXT]
|
259
267
|
}] }]; } });
|
260
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contragent-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.ts","../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this,@typescript-eslint/unbound-method,no-restricted-syntax */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject, Optional } from '@angular/core';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { UntilDestroy } from '@ngneat/until-destroy';\nimport {\n    ScContragent,\n    ScContragentOnDataCreate,\n    ScContragentService,\n    ScConvertersService,\n    ScIBankAccount,\n    ScICountry,\n    ScICurrency,\n    ScIReferencesTypes,\n    ScISalesDirection,\n    ScLocationsService,\n    ScOpfList,\n    ScReferencesService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { scBicValidator, scCorrespondentAccountValidator } from '../../validators';\n\n/**\n * Компотен добавления контрагента.\n */\n@Component({\n    selector: 'sc-add-contragent-dialog',\n    templateUrl: './sc-add-contragent-dialog.component.html',\n    styleUrls: ['./sc-add-contragent-dialog.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\n@UntilDestroy({ checkProperties: true })\nexport class ScAddContragentDialogComponent {\n    /**\n     * Перечисление организационно-правовых форм.\n     */\n    public readonly opfListEnum: typeof ScOpfList = ScOpfList;\n\n    /**\n     * Расположение баннера.\n     */\n    public stepIndex = 0;\n\n    /**\n     * Родительская `FormGroup`.\n     */\n    public form = new FormGroup({\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        contragent: new FormGroup<any>({}),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контрагента.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value.contragent as ScContragentOnDataCreate),\n        filter((value): value is ScContragentOnDataCreate => this.form.valid),\n        switchMap((value) => {\n            return this.contragentService.createContragent$(this.convertersService.removeNullRecursive(value)).pipe(\n                tap((contragent) => {\n                    this.context.completeWith(contragent);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n\n                        this.stepIndex = 0;\n                    }\n\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContragentDialogComponent}.\n     *\n     * @param referencesService Сервис справочников.\n     * @param contragentService Сервис работы с контрагентами.\n     * @param convertersService Сервис конвертации данных.\n     * @param locationsService\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly referencesService: ScReferencesService,\n        private readonly contragentService: ScContragentService,\n        private readonly convertersService: ScConvertersService,\n        private readonly locationsService: ScLocationsService,\n        @Optional()\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScContragent, void>\n    ) {}\n\n    /**\n     * Текущий выбранный ОПФ.\n     */\n    public get selectOpf(): ScOpfList {\n        return this.opfListEnum[this.form.controls.contragent.controls['opf'].value as keyof typeof ScOpfList];\n    }\n\n    /**\n     * Список групп полей банковских реквизитов.\n     */\n    public get bankAccounts(): FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>> {\n        return this.form.controls.contragent.get('bankAccounts') as FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>>;\n    }\n\n    /**\n     * Список групп полей контактных лиц.\n     */\n    public get contacts(): FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>> {\n        return this.form.controls.contragent.get('contacts') as FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>>;\n    }\n\n    /**\n     * Выполняет навигацию по форме создания контрагента.\n     *\n     * @param delta Значение, на которое необходимо выполнить навигацию.\n     */\n    public navigate(delta: number): void {\n        this.stepIndex = (this.stepIndex + delta) % 3;\n    }\n\n    /**\n     * Проверяет, может ли пользователь перейти к следующему шагу создания контрагента.\n     *\n     * @returns Выводит значение `boolean` на основании {@link stepIndex}.\n     */\n    public canNextStep(): boolean {\n        switch (this.stepIndex) {\n            case 0:\n                for (const key in this.form.controls.contragent.controls) {\n                    if (\n                        Object.prototype.hasOwnProperty.call(this.form.controls.contragent.controls, key) &&\n                        !Array.isArray(this.form.controls.contragent.controls[key].value) &&\n                        this.form.controls.contragent.controls[key].invalid\n                    ) {\n                        return false;\n                    }\n                }\n\n                return true;\n            case 1:\n                return this.form.controls.contragent.controls['contacts'].valid;\n            case 2:\n                return this.form.controls.contragent.controls['bankAccounts'].valid;\n            default:\n                return true;\n        }\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     */\n    public getSalesDirections$(): Observable<ScISalesDirection[]> {\n        return this.referencesService.directions$;\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     *\n     * @param directionId\n     */\n    public getDirectionById$(directionId: number): Observable<ScISalesDirection | undefined> {\n        return this.referencesService.getDirectionById$(directionId);\n    }\n\n    /**\n     * Возвращает {@link Observable} список организационно-правовых форм.\n     */\n    public getOpf$(): Observable<Array<ScIReferencesTypes<ScOpfList, typeof ScOpfList>>> {\n        return this.referencesService.opf$;\n    }\n\n    /**\n     * Возвращает {@link Observable} организационно-правовой формы, соответствующий символьному обозначению (slug) на входе.\n     *\n     * @param slug Символьное обозначение (slug).\n     */\n    public getOpfBySlug$(slug: keyof typeof ScOpfList): Observable<ScIReferencesTypes<ScOpfList, typeof ScOpfList> | undefined> {\n        return this.referencesService.getOpfBySlug$(slug);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка валют.\n     */\n    public getCurrencies$(): Observable<ScICurrency[]> {\n        return this.referencesService.currencies$;\n    }\n\n    /**\n     * Возвращает {@link Observable} валюты, соответствующий идентификатору на входе.\n     *\n     * @param currencyId — Идентификатор валюты.\n     */\n    public getCurrencyById$(currencyId: number): Observable<ScICurrency | undefined> {\n        return this.referencesService.getCurrencyById$(currencyId);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка стран.\n     */\n    public getCountries$(): Observable<ScICountry[]> {\n        return this.locationsService.getCountries$();\n    }\n\n    /**\n     * Возвращает {@link Observable} страны, соответствующий идентификатору на входе.\n     *\n     * @param countryId — Идентификатор страны.\n     */\n    public getCountriesById$(countryId: number): Observable<ScICountry | undefined> {\n        return this.locationsService.getCountries$().pipe(map((countries) => countries.find((country) => country.id === countryId)));\n    }\n\n    /**\n     * Создаёт группу полей банковских реквизитов.\n     */\n    private createBankAccountGroup(): FormGroup<{\n        bankName: FormControl<string | null>;\n        bic: FormControl<string | null>;\n        accountNumber: FormControl<string | null>;\n        correspondentAccount: FormControl<string | null>;\n        currencyId: FormControl<number | null>;\n    }> {\n        return new FormGroup({\n            bankName: new FormControl<string | null>(null, Validators.required),\n            bic: new FormControl<string | null>(null, [Validators.required, Validators.minLength(9), scBicValidator]),\n            accountNumber: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20)]),\n            correspondentAccount: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),\n            currencyId: new FormControl<number | null>(null, Validators.required),\n        });\n    }\n\n    /**\n     * Добавляет Банковские реквизиты.\n     */\n    public addBankAccountGroup(): void {\n        this.bankAccounts.push(this.createBankAccountGroup());\n    }\n\n    /**\n     * Удаляет банковские реквизиты.\n     *\n     * @param index Индекс банковских реквизитов.\n     */\n    public removeBankAccountGroup(index: number): void {\n        this.bankAccounts.removeAt(index);\n    }\n\n    /**\n     * Создаёт группу полей контактного лица.\n     */\n    public createContactGroup(): FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }> {\n        return new FormGroup({\n            name: new FormControl<string | null>(null, Validators.required),\n            phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n            email: new FormControl<string | null>(null, Validators.email),\n            position: new FormControl<string | null>(null),\n        });\n    }\n\n    /**\n     * Добавляет контактное лицо контрагента.\n     */\n    public addContactGroup(): void {\n        this.contacts.push(this.createContactGroup());\n    }\n\n    /**\n     * Удаляет контактное лицо контрагента.\n     *\n     * @param index Индекс контактного лица.\n     */\n    public removeContactGroup(index: number): void {\n        this.contacts.removeAt(index);\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-4\"\n>\n    <tui-elastic-container>\n        <sc-new-contragent-form [class.!hidden]=\"stepIndex !== 0\"></sc-new-contragent-form>\n\n        <div [class.!hidden]=\"stepIndex !== 1\">\n            <div\n                *ngIf=\"contacts\"\n                class=\"flex flex-col gap-5 pb-1\"\n            >\n                <p class=\"text-lg font-bold\">Контакты</p>\n                <div\n                    *ngFor=\"let contact of contacts.controls; let index = index; let count = count; let last = last\"\n                    class=\"flex flex-col gap-3\"\n                >\n                    <div class=\"flex h-10 items-center justify-between\">\n                        <p class=\"font-bold\">Контакт №{{ index + 1 }}:</p>\n                        <button\n                            *ngIf=\"count - 1\"\n                            tuiIconButton\n                            appearance=\"secondary\"\n                            (click)=\"removeContactGroup(index)\"\n                            icon=\"tuiIconTrash2Large\"\n                        ></button>\n                    </div>\n                    <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n                    <hr\n                        *ngIf=\"!last\"\n                        class=\"h-px w-full bg-tui-base-04\"\n                    />\n                </div>\n                <button\n                    tuiButton\n                    icon=\"tuiIconPlusLarge\"\n                    [appearance]=\"'secondary'\"\n                    (click)=\"addContactGroup()\"\n                    type=\"button\"\n                >\n                    Добавить контакт\n                </button>\n            </div>\n        </div>\n\n        <div [class.!hidden]=\"stepIndex !== 2\">\n            <div\n                *ngIf=\"bankAccounts\"\n                class=\"flex flex-col gap-5 pb-1\"\n            >\n                <p class=\"text-lg font-bold\">Банковские реквизиты</p>\n                <div\n                    *ngFor=\"let bankAccount of bankAccounts.controls; let index = index; let count = count; let last = last\"\n                    class=\"flex flex-col gap-3\"\n                >\n                    <div class=\"flex h-12 items-center justify-between\">\n                        <p class=\"font-bold\">Банковские реквизиты №{{ index + 1 }}:</p>\n                        <button\n                            *ngIf=\"count - 1\"\n                            tuiIconButton\n                            appearance=\"secondary\"\n                            (click)=\"removeBankAccountGroup(index)\"\n                            icon=\"tuiIconTrash2Large\"\n                        ></button>\n                    </div>\n                    <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n                    <hr\n                        *ngIf=\"!last\"\n                        class=\"h-px w-full bg-tui-base-04\"\n                    />\n                </div>\n                <button\n                    tuiButton\n                    icon=\"tuiIconPlusLarge\"\n                    [appearance]=\"'secondary'\"\n                    (click)=\"addBankAccountGroup()\"\n                    type=\"button\"\n                >\n                    Добавить банковские реквизиты\n                </button>\n            </div>\n        </div>\n    </tui-elastic-container>\n    <div class=\"flex justify-center gap-2\">\n        <button\n            *ngIf=\"stepIndex > 0\"\n            tuiButton\n            appearance=\"secondary\"\n            type=\"button\"\n            (click)=\"stepIndex = (stepIndex - 1) % 3\"\n        >\n            Назад\n        </button>\n        <button\n            *ngIf=\"stepIndex === 0\"\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            *ngIf=\"stepIndex === 2 || (stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']); else nextIndexBtn\"\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [showLoader]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            class=\"self-center\"\n        >\n            Создать\n        </button>\n        <ng-template #nextIndexBtn>\n            <button\n                tuiButton\n                [disabled]=\"!canNextStep()\"\n                type=\"button\"\n                (click)=\"stepIndex = (stepIndex + 1) % 3\"\n            >\n                Далее\n            </button>\n        </ng-template>\n    </div>\n</form>\n"]}
|
268
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-contragent-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.ts","../../../../../projects/client-ui/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable class-methods-use-this,@typescript-eslint/unbound-method,no-restricted-syntax */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Inject, Optional } from '@angular/core';\nimport { FormArray, FormControl, FormGroup, Validators } from '@angular/forms';\nimport { UntilDestroy } from '@ngneat/until-destroy';\nimport {\n    ScContragent,\n    ScContragentOnDataCreate,\n    ScContragentService,\n    ScConvertersService,\n    ScIBankAccount,\n    ScICountry,\n    ScICurrency,\n    ScIReferencesTypes,\n    ScISalesDirection,\n    ScLocationsService,\n    ScOpfList,\n    ScReferencesService,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../auth/interfaces/api-error-response';\nimport { scBicValidator, scCorrespondentAccountValidator } from '../../validators';\n\n/**\n * Компотен добавления контрагента.\n */\n@Component({\n    selector: 'sc-add-contragent-dialog',\n    templateUrl: './sc-add-contragent-dialog.component.html',\n    styleUrls: ['./sc-add-contragent-dialog.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\n@UntilDestroy({ checkProperties: true })\nexport class ScAddContragentDialogComponent implements AfterViewInit {\n    /**\n     * Перечисление организационно-правовых форм.\n     */\n    public readonly opfListEnum: typeof ScOpfList = ScOpfList;\n\n    /**\n     * Расположение баннера.\n     */\n    public stepIndex = 0;\n\n    /**\n     * Родительская `FormGroup`.\n     */\n    public form = new FormGroup({\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        contragent: new FormGroup<any>({}),\n    });\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса добавления контрагента.\n     */\n    private readonly request$ = this.onSubmit.pipe(\n        map(() => this.form.value.contragent as ScContragentOnDataCreate),\n        filter((value): value is ScContragentOnDataCreate => this.form.valid),\n        switchMap((value) => {\n            return this.contragentService.createContragent$(this.convertersService.removeNullRecursive(value)).pipe(\n                tap((contragent) => {\n                    this.context.completeWith(contragent);\n                }),\n                catchError((error: unknown) => {\n                    tuiMarkControlAsTouchedAndValidate(this.form);\n                    if (error instanceof HttpErrorResponse) {\n                        const { errors, message } = error.error as ApiErrorResponse;\n\n                        for (const key in errors) {\n                            if (Object.hasOwn(errors, key)) {\n                                this.form.get(key)?.setErrors({ serverResponse: errors[key] });\n                            }\n                        }\n\n                        if (!errors && message) {\n                            this.form.setErrors({ serverResponse: [message] });\n                        }\n\n                        this.stepIndex = 0;\n                    }\n\n                    return of({} as ScIBankAccount);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddContragentDialogComponent}.\n     *\n     * @param referencesService Сервис справочников.\n     * @param contragentService Сервис работы с контрагентами.\n     * @param convertersService Сервис конвертации данных.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param locationsService\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     */\n    public constructor(\n        private readonly referencesService: ScReferencesService,\n        private readonly contragentService: ScContragentService,\n        private readonly convertersService: ScConvertersService,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        private readonly locationsService: ScLocationsService,\n        @Optional()\n        @Inject(POLYMORPHEUS_CONTEXT)\n        public readonly context: TuiDialogContext<ScContragent, void>\n    ) {}\n\n    /** @inheritdoc */\n    public ngAfterViewInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.userProfileContragentAddShow,\n        });\n    }\n\n    /**\n     * Текущий выбранный ОПФ.\n     */\n    public get selectOpf(): ScOpfList {\n        return this.opfListEnum[this.form.controls.contragent.controls['opf'].value as keyof typeof ScOpfList];\n    }\n\n    /**\n     * Список групп полей банковских реквизитов.\n     */\n    public get bankAccounts(): FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>> {\n        return this.form.controls.contragent.get('bankAccounts') as FormArray<ReturnType<ScAddContragentDialogComponent['createBankAccountGroup']>>;\n    }\n\n    /**\n     * Список групп полей контактных лиц.\n     */\n    public get contacts(): FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>> {\n        return this.form.controls.contragent.get('contacts') as FormArray<ReturnType<ScAddContragentDialogComponent['createContactGroup']>>;\n    }\n\n    /**\n     * Выполняет навигацию по форме создания контрагента.\n     *\n     * @param delta Значение, на которое необходимо выполнить навигацию.\n     */\n    public navigate(delta: number): void {\n        this.stepIndex = (this.stepIndex + delta) % 3;\n    }\n\n    /**\n     * Проверяет, может ли пользователь перейти к следующему шагу создания контрагента.\n     *\n     * @returns Выводит значение `boolean` на основании {@link stepIndex}.\n     */\n    public canNextStep(): boolean {\n        switch (this.stepIndex) {\n            case 0:\n                for (const key in this.form.controls.contragent.controls) {\n                    if (\n                        Object.prototype.hasOwnProperty.call(this.form.controls.contragent.controls, key) &&\n                        !Array.isArray(this.form.controls.contragent.controls[key].value) &&\n                        this.form.controls.contragent.controls[key].invalid\n                    ) {\n                        return false;\n                    }\n                }\n\n                return true;\n            case 1:\n                return this.form.controls.contragent.controls['contacts'].valid;\n            case 2:\n                return this.form.controls.contragent.controls['bankAccounts'].valid;\n            default:\n                return true;\n        }\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     */\n    public getSalesDirections$(): Observable<ScISalesDirection[]> {\n        return this.referencesService.directions$;\n    }\n\n    /**\n     * Возвращает {@link Observable} списка направлений продаж.\n     *\n     * @param directionId\n     */\n    public getDirectionById$(directionId: number): Observable<ScISalesDirection | undefined> {\n        return this.referencesService.getDirectionById$(directionId);\n    }\n\n    /**\n     * Возвращает {@link Observable} список организационно-правовых форм.\n     */\n    public getOpf$(): Observable<Array<ScIReferencesTypes<ScOpfList, typeof ScOpfList>>> {\n        return this.referencesService.opf$;\n    }\n\n    /**\n     * Возвращает {@link Observable} организационно-правовой формы, соответствующий символьному обозначению (slug) на входе.\n     *\n     * @param slug Символьное обозначение (slug).\n     */\n    public getOpfBySlug$(slug: keyof typeof ScOpfList): Observable<ScIReferencesTypes<ScOpfList, typeof ScOpfList> | undefined> {\n        return this.referencesService.getOpfBySlug$(slug);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка валют.\n     */\n    public getCurrencies$(): Observable<ScICurrency[]> {\n        return this.referencesService.currencies$;\n    }\n\n    /**\n     * Возвращает {@link Observable} валюты, соответствующий идентификатору на входе.\n     *\n     * @param currencyId — Идентификатор валюты.\n     */\n    public getCurrencyById$(currencyId: number): Observable<ScICurrency | undefined> {\n        return this.referencesService.getCurrencyById$(currencyId);\n    }\n\n    /**\n     * Возвращает {@link Observable} списка стран.\n     */\n    public getCountries$(): Observable<ScICountry[]> {\n        return this.locationsService.getCountries$();\n    }\n\n    /**\n     * Возвращает {@link Observable} страны, соответствующий идентификатору на входе.\n     *\n     * @param countryId — Идентификатор страны.\n     */\n    public getCountriesById$(countryId: number): Observable<ScICountry | undefined> {\n        return this.locationsService.getCountries$().pipe(map((countries) => countries.find((country) => country.id === countryId)));\n    }\n\n    /**\n     * Создаёт группу полей банковских реквизитов.\n     */\n    private createBankAccountGroup(): FormGroup<{\n        bankName: FormControl<string | null>;\n        bic: FormControl<string | null>;\n        accountNumber: FormControl<string | null>;\n        correspondentAccount: FormControl<string | null>;\n        currencyId: FormControl<number | null>;\n    }> {\n        return new FormGroup({\n            bankName: new FormControl<string | null>(null, Validators.required),\n            bic: new FormControl<string | null>(null, [Validators.required, Validators.minLength(9), scBicValidator]),\n            accountNumber: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20)]),\n            correspondentAccount: new FormControl<string | null>(null, [Validators.required, Validators.minLength(20), scCorrespondentAccountValidator]),\n            currencyId: new FormControl<number | null>(null, Validators.required),\n        });\n    }\n\n    /**\n     * Добавляет Банковские реквизиты.\n     */\n    public addBankAccountGroup(): void {\n        this.bankAccounts.push(this.createBankAccountGroup());\n    }\n\n    /**\n     * Удаляет банковские реквизиты.\n     *\n     * @param index Индекс банковских реквизитов.\n     */\n    public removeBankAccountGroup(index: number): void {\n        this.bankAccounts.removeAt(index);\n    }\n\n    /**\n     * Создаёт группу полей контактного лица.\n     */\n    public createContactGroup(): FormGroup<{\n        name: FormControl<string | null>;\n        phone: FormControl<string | null>;\n        email: FormControl<string | null>;\n        position: FormControl<string | null>;\n    }> {\n        return new FormGroup({\n            name: new FormControl<string | null>(null, Validators.required),\n            phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n            email: new FormControl<string | null>(null, Validators.email),\n            position: new FormControl<string | null>(null),\n        });\n    }\n\n    /**\n     * Добавляет контактное лицо контрагента.\n     */\n    public addContactGroup(): void {\n        this.contacts.push(this.createContactGroup());\n    }\n\n    /**\n     * Удаляет контактное лицо контрагента.\n     *\n     * @param index Индекс контактного лица.\n     */\n    public removeContactGroup(index: number): void {\n        this.contacts.removeAt(index);\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit.next()\"\n    class=\"flex flex-col gap-4\"\n>\n    <tui-elastic-container>\n        <sc-new-contragent-form [class.!hidden]=\"stepIndex !== 0\"></sc-new-contragent-form>\n\n        <div [class.!hidden]=\"stepIndex !== 1\">\n            <div\n                *ngIf=\"contacts\"\n                class=\"flex flex-col gap-5 pb-1\"\n            >\n                <p class=\"text-lg font-bold\">Контакты</p>\n                <div\n                    *ngFor=\"let contact of contacts.controls; let index = index; let count = count; let last = last\"\n                    class=\"flex flex-col gap-3\"\n                >\n                    <div class=\"flex h-10 items-center justify-between\">\n                        <p class=\"font-bold\">Контакт №{{ index + 1 }}:</p>\n                        <button\n                            *ngIf=\"count - 1\"\n                            tuiIconButton\n                            appearance=\"secondary\"\n                            (click)=\"removeContactGroup(index)\"\n                            icon=\"tuiIconTrash2Large\"\n                        ></button>\n                    </div>\n                    <sc-new-contact-form [form]=\"contact\"></sc-new-contact-form>\n                    <hr\n                        *ngIf=\"!last\"\n                        class=\"h-px w-full bg-tui-base-04\"\n                    />\n                </div>\n                <button\n                    tuiButton\n                    icon=\"tuiIconPlusLarge\"\n                    [appearance]=\"'secondary'\"\n                    (click)=\"addContactGroup()\"\n                    type=\"button\"\n                >\n                    Добавить контакт\n                </button>\n            </div>\n        </div>\n\n        <div [class.!hidden]=\"stepIndex !== 2\">\n            <div\n                *ngIf=\"bankAccounts\"\n                class=\"flex flex-col gap-5 pb-1\"\n            >\n                <p class=\"text-lg font-bold\">Банковские реквизиты</p>\n                <div\n                    *ngFor=\"let bankAccount of bankAccounts.controls; let index = index; let count = count; let last = last\"\n                    class=\"flex flex-col gap-3\"\n                >\n                    <div class=\"flex h-12 items-center justify-between\">\n                        <p class=\"font-bold\">Банковские реквизиты №{{ index + 1 }}:</p>\n                        <button\n                            *ngIf=\"count - 1\"\n                            tuiIconButton\n                            appearance=\"secondary\"\n                            (click)=\"removeBankAccountGroup(index)\"\n                            icon=\"tuiIconTrash2Large\"\n                        ></button>\n                    </div>\n                    <sc-new-contragent-bank-account-form [form]=\"bankAccount\"></sc-new-contragent-bank-account-form>\n                    <hr\n                        *ngIf=\"!last\"\n                        class=\"h-px w-full bg-tui-base-04\"\n                    />\n                </div>\n                <button\n                    tuiButton\n                    icon=\"tuiIconPlusLarge\"\n                    [appearance]=\"'secondary'\"\n                    (click)=\"addBankAccountGroup()\"\n                    type=\"button\"\n                >\n                    Добавить банковские реквизиты\n                </button>\n            </div>\n        </div>\n    </tui-elastic-container>\n    <div class=\"flex justify-center gap-2\">\n        <button\n            *ngIf=\"stepIndex > 0\"\n            tuiButton\n            appearance=\"secondary\"\n            type=\"button\"\n            (click)=\"stepIndex = (stepIndex - 1) % 3\"\n        >\n            Назад\n        </button>\n        <button\n            *ngIf=\"stepIndex === 0\"\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            *ngIf=\"stepIndex === 2 || (stepIndex === 1 && !form.controls.contragent.controls['bankAccounts']); else nextIndexBtn\"\n            tuiButton\n            [disabled]=\"form.invalid\"\n            [showLoader]=\"!!(loading$ | async)\"\n            type=\"submit\"\n            class=\"self-center\"\n        >\n            Создать\n        </button>\n        <ng-template #nextIndexBtn>\n            <button\n                tuiButton\n                [disabled]=\"!canNextStep()\"\n                type=\"button\"\n                (click)=\"stepIndex = (stepIndex + 1) % 3\"\n            >\n                Далее\n            </button>\n        </ng-template>\n    </div>\n</form>\n"]}
|
@@ -1,6 +1,6 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, Inject, inject } from '@angular/core';
|
2
2
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
3
|
-
import { ScISuggestionType } from '@snabcentr/client-core';
|
3
|
+
import { ScISuggestionType, ScUserMetrikaGoalsEnum, } from '@snabcentr/client-core';
|
4
4
|
import { TUI_IS_MOBILE, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';
|
5
5
|
import { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';
|
6
6
|
import { catchError, filter, map, of, share, startWith, Subject, switchMap, tap } from 'rxjs';
|
@@ -21,11 +21,13 @@ export class ScAddDeliveryAddressDialogComponent {
|
|
21
21
|
* Инициализирует экземпляр класса {@link ScAddDeliveryAddressDialogComponent}.
|
22
22
|
*
|
23
23
|
* @param deliveryAddressService Сервис работы с адресами доставки.
|
24
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
24
25
|
* @param context Контекст диалогового окна, в котором открыт компонент.
|
25
26
|
* @param convertersService Сервис конвертации данных.
|
26
27
|
*/
|
27
|
-
constructor(deliveryAddressService, context, convertersService) {
|
28
|
+
constructor(deliveryAddressService, userMetrikaService, context, convertersService) {
|
28
29
|
this.deliveryAddressService = deliveryAddressService;
|
30
|
+
this.userMetrikaService = userMetrikaService;
|
29
31
|
this.context = context;
|
30
32
|
this.convertersService = convertersService;
|
31
33
|
/**
|
@@ -74,14 +76,20 @@ export class ScAddDeliveryAddressDialogComponent {
|
|
74
76
|
}),
|
75
77
|
});
|
76
78
|
}
|
79
|
+
/** @inheritdoc */
|
80
|
+
ngAfterViewInit() {
|
81
|
+
this.userMetrikaService.emitUserMetrikaEvent({
|
82
|
+
target: ScUserMetrikaGoalsEnum.userProfileDeliveryAddressAddShow,
|
83
|
+
});
|
84
|
+
}
|
77
85
|
}
|
78
|
-
ScAddDeliveryAddressDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddDeliveryAddressDialogComponent, deps: [{ token: i1.ScDeliveryAddressService }, { token: POLYMORPHEUS_CONTEXT }, { token: i1.ScConvertersService }], target: i0.ɵɵFactoryTarget.Component });
|
86
|
+
ScAddDeliveryAddressDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddDeliveryAddressDialogComponent, deps: [{ token: i1.ScDeliveryAddressService }, { token: i1.ScUserMetrikaService }, { token: POLYMORPHEUS_CONTEXT }, { token: i1.ScConvertersService }], target: i0.ɵɵFactoryTarget.Component });
|
79
87
|
ScAddDeliveryAddressDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScAddDeliveryAddressDialogComponent, selector: "sc-add-delivery-address-dialog", ngImport: i0, template: "<form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit$.next()\"\n class=\"flex flex-col gap-3\"\n>\n <label tuiLabel=\"\u0410\u0434\u0440\u0435\u0441 \u0434\u043E\u0441\u0442\u0430\u0432\u043A\u0438\">\n <tui-input formControlName=\"address\">\n \u0410\u0434\u0440\u0435\u0441 \u0434\u043E\u0441\u0442\u0430\u0432\u043A\u0438\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.address\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"address\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <div\n formGroupName=\"contact\"\n class=\"flex grow flex-col gap-2\"\n >\n <p class=\"w-full font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u043D\u043E\u0435 \u043B\u0438\u0446\u043E:</p>\n <label tuiLabel=\"\u0424.\u0418.\u041E.\">\n <tui-input formControlName=\"name\">\n \u0424.\u0418.\u041E.\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.fio\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"name\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0422\u0435\u043B\u0435\u0444\u043E\u043D\">\n <tui-input-phone formControlName=\"phone\"> \u0422\u0435\u043B\u0435\u0444\u043E\u043D </tui-input-phone>\n <tui-error\n formControlName=\"phone\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\">\n <tui-input formControlName=\"email\">\n <input\n tuiTextfield\n type=\"email\"\n />\n \u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.email\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"email\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0414\u043E\u043B\u0436\u043D\u043E\u0441\u0442\u044C\">\n <tui-input formControlName=\"position\"> \u0414\u043E\u043B\u0436\u043D\u043E\u0441\u0442\u044C </tui-input>\n <tui-error\n formControlName=\"position\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n </div>\n <div class=\"flex justify-center gap-8\">\n <button\n tuiButton\n (click)=\"context.$implicit.complete()\"\n type=\"button\"\n tuiMode=\"onLight\"\n [icon]=\"isMobile ? 'tuiIconX' : 'tuiIconXLarge'\"\n appearance=\"secondary\"\n >\n \u041E\u0442\u043C\u0435\u043D\u0430\n </button>\n <button\n tuiButton\n [icon]=\"isMobile ? 'tuiIconSave' : 'tuiIconSaveLarge'\"\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\n </button>\n </div>\n</form>\n", dependencies: [{ kind: "component", type: i2.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i2.TuiModeDirective, selector: "[tuiMode]", inputs: ["tuiMode"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i3.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i2.TuiLabelComponent, selector: "label[tuiLabel]", inputs: ["tuiLabel", "context"] }, { kind: "component", type: i2.TuiErrorComponent, selector: "tui-error", inputs: ["error"] }, { kind: "component", type: i4.TuiInputComponent, selector: "tui-input" }, { kind: "directive", type: i4.TuiInputDirective, selector: "tui-input" }, { kind: "component", type: i2.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }, { kind: "component", type: i4.TuiInputPhoneComponent, selector: "tui-input-phone", inputs: ["countryCode", "phoneMaskAfterCountryCode", "allowText", "search"], outputs: ["searchChange"] }, { kind: "directive", type: i4.TuiInputPhoneDirective, selector: "tui-input-phone" }, { kind: "component", type: i5.ScSuggestionFieldComponent, selector: "sc-suggestion-field", inputs: ["type"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: i4.TuiFieldErrorPipe, name: "tuiFieldError" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
80
88
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScAddDeliveryAddressDialogComponent, decorators: [{
|
81
89
|
type: Component,
|
82
90
|
args: [{ selector: 'sc-add-delivery-address-dialog', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit$.next()\"\n class=\"flex flex-col gap-3\"\n>\n <label tuiLabel=\"\u0410\u0434\u0440\u0435\u0441 \u0434\u043E\u0441\u0442\u0430\u0432\u043A\u0438\">\n <tui-input formControlName=\"address\">\n \u0410\u0434\u0440\u0435\u0441 \u0434\u043E\u0441\u0442\u0430\u0432\u043A\u0438\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.address\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"address\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <div\n formGroupName=\"contact\"\n class=\"flex grow flex-col gap-2\"\n >\n <p class=\"w-full font-bold\">\u041A\u043E\u043D\u0442\u0430\u043A\u0442\u043D\u043E\u0435 \u043B\u0438\u0446\u043E:</p>\n <label tuiLabel=\"\u0424.\u0418.\u041E.\">\n <tui-input formControlName=\"name\">\n \u0424.\u0418.\u041E.\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.fio\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"name\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0422\u0435\u043B\u0435\u0444\u043E\u043D\">\n <tui-input-phone formControlName=\"phone\"> \u0422\u0435\u043B\u0435\u0444\u043E\u043D </tui-input-phone>\n <tui-error\n formControlName=\"phone\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\">\n <tui-input formControlName=\"email\">\n <input\n tuiTextfield\n type=\"email\"\n />\n \u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\n <sc-suggestion-field\n *tuiDataList\n [type]=\"suggestionType.email\"\n ></sc-suggestion-field>\n </tui-input>\n <tui-error\n formControlName=\"email\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n <label tuiLabel=\"\u0414\u043E\u043B\u0436\u043D\u043E\u0441\u0442\u044C\">\n <tui-input formControlName=\"position\"> \u0414\u043E\u043B\u0436\u043D\u043E\u0441\u0442\u044C </tui-input>\n <tui-error\n formControlName=\"position\"\n [error]=\"[] | tuiFieldError | async\"\n ></tui-error>\n </label>\n </div>\n <div class=\"flex justify-center gap-8\">\n <button\n tuiButton\n (click)=\"context.$implicit.complete()\"\n type=\"button\"\n tuiMode=\"onLight\"\n [icon]=\"isMobile ? 'tuiIconX' : 'tuiIconXLarge'\"\n appearance=\"secondary\"\n >\n \u041E\u0442\u043C\u0435\u043D\u0430\n </button>\n <button\n tuiButton\n [icon]=\"isMobile ? 'tuiIconSave' : 'tuiIconSaveLarge'\"\n [disabled]=\"form.invalid\"\n [showLoader]=\"!!(loading$ | async)\"\n type=\"submit\"\n >\n \u0414\u043E\u0431\u0430\u0432\u0438\u0442\u044C\n </button>\n </div>\n</form>\n" }]
|
83
|
-
}], ctorParameters: function () { return [{ type: i1.ScDeliveryAddressService }, { type: undefined, decorators: [{
|
91
|
+
}], ctorParameters: function () { return [{ type: i1.ScDeliveryAddressService }, { type: i1.ScUserMetrikaService }, { type: undefined, decorators: [{
|
84
92
|
type: Inject,
|
85
93
|
args: [POLYMORPHEUS_CONTEXT]
|
86
94
|
}] }, { type: i1.ScConvertersService }]; } });
|
87
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-delivery-address-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.ts","../../../../../projects/client-ui/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable rxjs/no-implicit-any-catch,guard-for-in,no-restricted-syntax,@typescript-eslint/no-unnecessary-condition,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, Inject, inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { ScConvertersService, ScDeliveryAddressService, ScIDeliveryAddress, ScIDeliveryAddressOnDataCreate, ScISuggestionType } from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { ApiErrorResponse } from 'projects/client-ui/auth';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\n/**\n * Компонент добавления адреса доставки.\n *\n * TODO: TASK[8813] Добавить карту, и поведение выбора адреса доставки через карту. При этом вынести форму в отдельный компонент AddDeliveryAddressForm или submit логику в директиву.\n */\n@Component({\n    selector: 'sc-add-delivery-address-dialog',\n    templateUrl: './sc-add-delivery-address-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddDeliveryAddressDialogComponent {\n    /**\n     * Признак того, отображается этот компонент на мобильном устройстве или нет.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit$: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса данных добавления адрес доставки.\n     */\n    private readonly request$: Observable<ScIDeliveryAddress | null | undefined> = this.onSubmit$.pipe(\n        tap(() => {\n            tuiMarkControlAsTouchedAndValidate(this.form);\n        }),\n        filter(() => this.form.valid),\n        map(() => this.form.value as ScIDeliveryAddressOnDataCreate),\n        switchMap((value) =>\n            this.deliveryAddressService.createDeliveryAddress$(this.convertersService.removeNullRecursive<ScIDeliveryAddressOnDataCreate>(value)).pipe(\n                catchError((error: HttpErrorResponse) => {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    for (const key in errorResponse.errors) {\n                        this.form.get(key)?.setErrors({ serverResponse: errorResponse.errors[key] });\n                    }\n\n                    if (!errorResponse.errors && errorResponse.message) {\n                        this.form.setErrors({ serverResponse: [errorResponse.message] });\n                    }\n\n                    return of();\n                }),\n                tap(() => {\n                    this.context.completeWith();\n                }),\n                startWith(null)\n            )\n        ),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map((data) => data === null));\n\n    /**\n     * Форма для создания адреса доставки.\n     */\n    public readonly form = new FormGroup({\n        address: new FormControl<string | null>(null, Validators.required),\n        contact: new FormGroup({\n            name: new FormControl<string | null>(null, Validators.required),\n            phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n            email: new FormControl<string | null>(null, Validators.email),\n            position: new FormControl<string | null>(null),\n        }),\n    });\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddDeliveryAddressDialogComponent}.\n     *\n     * @param deliveryAddressService Сервис работы с адресами доставки.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     * @param convertersService Сервис конвертации данных.\n     */\n    public constructor(\n        private readonly deliveryAddressService: ScDeliveryAddressService,\n        @Inject(POLYMORPHEUS_CONTEXT) public readonly context: TuiDialogContext<void, void>,\n        private readonly convertersService: ScConvertersService\n    ) {}\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit$.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <label tuiLabel=\"Адрес доставки\">\n        <tui-input formControlName=\"address\">\n            Адрес доставки\n            <sc-suggestion-field\n                *tuiDataList\n                [type]=\"suggestionType.address\"\n            ></sc-suggestion-field>\n        </tui-input>\n        <tui-error\n            formControlName=\"address\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n    <div\n        formGroupName=\"contact\"\n        class=\"flex grow flex-col gap-2\"\n    >\n        <p class=\"w-full font-bold\">Контактное лицо:</p>\n        <label tuiLabel=\"Ф.И.О.\">\n            <tui-input formControlName=\"name\">\n                Ф.И.О.\n                <sc-suggestion-field\n                    *tuiDataList\n                    [type]=\"suggestionType.fio\"\n                ></sc-suggestion-field>\n            </tui-input>\n            <tui-error\n                formControlName=\"name\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Телефон\">\n            <tui-input-phone formControlName=\"phone\"> Телефон </tui-input-phone>\n            <tui-error\n                formControlName=\"phone\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Адрес электронной почты\">\n            <tui-input formControlName=\"email\">\n                <input\n                    tuiTextfield\n                    type=\"email\"\n                />\n                Адрес электронной почты\n                <sc-suggestion-field\n                    *tuiDataList\n                    [type]=\"suggestionType.email\"\n                ></sc-suggestion-field>\n            </tui-input>\n            <tui-error\n                formControlName=\"email\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Должность\">\n            <tui-input formControlName=\"position\"> Должность </tui-input>\n            <tui-error\n                formControlName=\"position\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n    </div>\n    <div class=\"flex justify-center gap-8\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            tuiMode=\"onLight\"\n            [icon]=\"isMobile ? 'tuiIconX' : 'tuiIconXLarge'\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [icon]=\"isMobile ? 'tuiIconSave' : 'tuiIconSaveLarge'\"\n            [disabled]=\"form.invalid\"\n            [showLoader]=\"!!(loading$ | async)\"\n            type=\"submit\"\n        >\n            Добавить\n        </button>\n    </div>\n</form>\n"]}
|
95
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-add-delivery-address-dialog.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.ts","../../../../../projects/client-ui/delivery-address/add-delivery-address-dialog/sc-add-delivery-address-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable rxjs/no-implicit-any-catch,guard-for-in,no-restricted-syntax,@typescript-eslint/no-unnecessary-condition,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { AfterViewInit, ChangeDetectionStrategy, Component, Inject, inject } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    ScConvertersService,\n    ScDeliveryAddressService,\n    ScIDeliveryAddress,\n    ScIDeliveryAddressOnDataCreate,\n    ScISuggestionType,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n} from '@snabcentr/client-core';\nimport { TUI_IS_MOBILE, tuiMarkControlAsTouchedAndValidate } from '@taiga-ui/cdk';\nimport { TuiDialogContext } from '@taiga-ui/core';\nimport { POLYMORPHEUS_CONTEXT } from '@tinkoff/ng-polymorpheus';\nimport { ApiErrorResponse } from 'projects/client-ui/auth';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap, tap } from 'rxjs';\n\n/**\n * Компонент добавления адреса доставки.\n *\n * TODO: TASK[8813] Добавить карту, и поведение выбора адреса доставки через карту. При этом вынести форму в отдельный компонент AddDeliveryAddressForm или submit логику в директиву.\n */\n@Component({\n    selector: 'sc-add-delivery-address-dialog',\n    templateUrl: './sc-add-delivery-address-dialog.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScAddDeliveryAddressDialogComponent implements AfterViewInit {\n    /**\n     * Признак того, отображается этот компонент на мобильном устройстве или нет.\n     */\n    public readonly isMobile: boolean = inject(TUI_IS_MOBILE);\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    public readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    public readonly onSubmit$: Subject<void> = new Subject<void>();\n\n    /**\n     * {@link Observable} запроса данных добавления адрес доставки.\n     */\n    private readonly request$: Observable<ScIDeliveryAddress | null | undefined> = this.onSubmit$.pipe(\n        tap(() => {\n            tuiMarkControlAsTouchedAndValidate(this.form);\n        }),\n        filter(() => this.form.valid),\n        map(() => this.form.value as ScIDeliveryAddressOnDataCreate),\n        switchMap((value) =>\n            this.deliveryAddressService.createDeliveryAddress$(this.convertersService.removeNullRecursive<ScIDeliveryAddressOnDataCreate>(value)).pipe(\n                catchError((error: HttpErrorResponse) => {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    for (const key in errorResponse.errors) {\n                        this.form.get(key)?.setErrors({ serverResponse: errorResponse.errors[key] });\n                    }\n\n                    if (!errorResponse.errors && errorResponse.message) {\n                        this.form.setErrors({ serverResponse: [errorResponse.message] });\n                    }\n\n                    return of();\n                }),\n                tap(() => {\n                    this.context.completeWith();\n                }),\n                startWith(null)\n            )\n        ),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных.\n     */\n    public readonly loading$: Observable<boolean> = this.request$.pipe(map((data) => data === null));\n\n    /**\n     * Форма для создания адреса доставки.\n     */\n    public readonly form = new FormGroup({\n        address: new FormControl<string | null>(null, Validators.required),\n        contact: new FormGroup({\n            name: new FormControl<string | null>(null, Validators.required),\n            phone: new FormControl<string | null>(null, [Validators.required, Validators.minLength(12)]),\n            email: new FormControl<string | null>(null, Validators.email),\n            position: new FormControl<string | null>(null),\n        }),\n    });\n\n    /**\n     * Инициализирует экземпляр класса {@link ScAddDeliveryAddressDialogComponent}.\n     *\n     * @param deliveryAddressService Сервис работы с адресами доставки.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     * @param context Контекст диалогового окна, в котором открыт компонент.\n     * @param convertersService Сервис конвертации данных.\n     */\n    public constructor(\n        private readonly deliveryAddressService: ScDeliveryAddressService,\n        private readonly userMetrikaService: ScUserMetrikaService,\n        @Inject(POLYMORPHEUS_CONTEXT) public readonly context: TuiDialogContext<void, void>,\n        private readonly convertersService: ScConvertersService\n    ) {}\n\n    /** @inheritdoc */\n    public ngAfterViewInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.userProfileDeliveryAddressAddShow,\n        });\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit$.next()\"\n    class=\"flex flex-col gap-3\"\n>\n    <label tuiLabel=\"Адрес доставки\">\n        <tui-input formControlName=\"address\">\n            Адрес доставки\n            <sc-suggestion-field\n                *tuiDataList\n                [type]=\"suggestionType.address\"\n            ></sc-suggestion-field>\n        </tui-input>\n        <tui-error\n            formControlName=\"address\"\n            [error]=\"[] | tuiFieldError | async\"\n        ></tui-error>\n    </label>\n    <div\n        formGroupName=\"contact\"\n        class=\"flex grow flex-col gap-2\"\n    >\n        <p class=\"w-full font-bold\">Контактное лицо:</p>\n        <label tuiLabel=\"Ф.И.О.\">\n            <tui-input formControlName=\"name\">\n                Ф.И.О.\n                <sc-suggestion-field\n                    *tuiDataList\n                    [type]=\"suggestionType.fio\"\n                ></sc-suggestion-field>\n            </tui-input>\n            <tui-error\n                formControlName=\"name\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Телефон\">\n            <tui-input-phone formControlName=\"phone\"> Телефон </tui-input-phone>\n            <tui-error\n                formControlName=\"phone\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Адрес электронной почты\">\n            <tui-input formControlName=\"email\">\n                <input\n                    tuiTextfield\n                    type=\"email\"\n                />\n                Адрес электронной почты\n                <sc-suggestion-field\n                    *tuiDataList\n                    [type]=\"suggestionType.email\"\n                ></sc-suggestion-field>\n            </tui-input>\n            <tui-error\n                formControlName=\"email\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n        <label tuiLabel=\"Должность\">\n            <tui-input formControlName=\"position\"> Должность </tui-input>\n            <tui-error\n                formControlName=\"position\"\n                [error]=\"[] | tuiFieldError | async\"\n            ></tui-error>\n        </label>\n    </div>\n    <div class=\"flex justify-center gap-8\">\n        <button\n            tuiButton\n            (click)=\"context.$implicit.complete()\"\n            type=\"button\"\n            tuiMode=\"onLight\"\n            [icon]=\"isMobile ? 'tuiIconX' : 'tuiIconXLarge'\"\n            appearance=\"secondary\"\n        >\n            Отмена\n        </button>\n        <button\n            tuiButton\n            [icon]=\"isMobile ? 'tuiIconSave' : 'tuiIconSaveLarge'\"\n            [disabled]=\"form.invalid\"\n            [showLoader]=\"!!(loading$ | async)\"\n            type=\"submit\"\n        >\n            Добавить\n        </button>\n    </div>\n</form>\n"]}
|