@snabcentr/client-ui 3.44.13 → 3.45.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/auth/sign-up-form/sc-sign-up-form.component.d.ts +14 -9
- package/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.d.ts +21 -24
- package/contragents/new-contragent-form/sc-new-contragent-form.component.d.ts +12 -18
- package/esm2022/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.mjs +1 -2
- package/esm2022/auth/sign-up-form/sc-sign-up-form.component.mjs +37 -36
- package/esm2022/contragents/add-contragent-dialog/sc-add-contragent-dialog.component.mjs +38 -50
- package/esm2022/contragents/new-contragent-form/sc-new-contragent-form.component.mjs +28 -46
- package/fesm2022/snabcentr-client-ui.mjs +119 -146
- package/fesm2022/snabcentr-client-ui.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit, OutputEmitterRef, OutputRef } from '@angular/core';
|
|
2
2
|
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
|
-
import {
|
|
3
|
+
import { ScIReferencesTypes, ScISuggestionType, ScOpfList, ScSuggestion, ScUser } from '@snabcentr/client-core';
|
|
4
4
|
import { Observable, Subject } from 'rxjs';
|
|
5
5
|
import { ScContactFormGroup } from '../interfaces';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -8,10 +8,21 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
* Компонент формы регистрация пользователя.
|
|
9
9
|
*/
|
|
10
10
|
export declare class ScSignUpFormComponent implements OnInit {
|
|
11
|
+
/**
|
|
12
|
+
* Сервис данных о пользователе.
|
|
13
|
+
*/
|
|
11
14
|
private readonly userService;
|
|
12
|
-
|
|
15
|
+
/**
|
|
16
|
+
* Сервис справочников.
|
|
17
|
+
*/
|
|
13
18
|
private readonly referencesService;
|
|
19
|
+
/**
|
|
20
|
+
* Сервис конвертации данных.
|
|
21
|
+
*/
|
|
14
22
|
private readonly convertersService;
|
|
23
|
+
/**
|
|
24
|
+
* Сервис для сбора метрик о действиях пользователей.
|
|
25
|
+
*/
|
|
15
26
|
private readonly userMetrikaService;
|
|
16
27
|
/**
|
|
17
28
|
* Поле ввода организационно-правовых форм.
|
|
@@ -70,14 +81,8 @@ export declare class ScSignUpFormComponent implements OnInit {
|
|
|
70
81
|
readonly steps: string[];
|
|
71
82
|
/**
|
|
72
83
|
* Инициализирует экземпляр класса {@link ScSignUpFormComponent}.
|
|
73
|
-
*
|
|
74
|
-
* @param userService Сервис данных о пользователе.
|
|
75
|
-
* @param authService Сервис аутентификации.
|
|
76
|
-
* @param referencesService Сервис справочников.
|
|
77
|
-
* @param convertersService Сервис конвертации данных.
|
|
78
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
|
79
84
|
*/
|
|
80
|
-
constructor(
|
|
85
|
+
constructor();
|
|
81
86
|
/**
|
|
82
87
|
* Список групп полей банковских реквизитов.
|
|
83
88
|
*/
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { AfterViewInit } from '@angular/core';
|
|
2
2
|
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
|
-
import { ScContragent,
|
|
3
|
+
import { ScContragent, ScICountry, ScICurrency, ScIReferencesTypes, ScOpfList } from '@snabcentr/client-core';
|
|
4
4
|
import { TuiDialogContext } from '@taiga-ui/core';
|
|
5
5
|
import { Observable, Subject } from 'rxjs';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -8,12 +8,30 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
* Компотен добавления контрагента.
|
|
9
9
|
*/
|
|
10
10
|
export declare class ScAddContragentDialogComponent implements AfterViewInit {
|
|
11
|
+
/**
|
|
12
|
+
* Сервис справочников.
|
|
13
|
+
*/
|
|
11
14
|
private readonly referencesService;
|
|
15
|
+
/**
|
|
16
|
+
* Сервис работы с контрагентами.
|
|
17
|
+
*/
|
|
12
18
|
private readonly contragentService;
|
|
19
|
+
/**
|
|
20
|
+
* Сервис конвертации данных.
|
|
21
|
+
*/
|
|
13
22
|
private readonly convertersService;
|
|
23
|
+
/**
|
|
24
|
+
* Сервис для сбора метрик о действиях пользователей.
|
|
25
|
+
*/
|
|
14
26
|
private readonly userMetrikaService;
|
|
27
|
+
/**
|
|
28
|
+
* Сервис для получения списков стран, регионов, городов.
|
|
29
|
+
*/
|
|
15
30
|
private readonly locationsService;
|
|
16
|
-
|
|
31
|
+
/**
|
|
32
|
+
* Контекст диалогового окна, в котором открыт компонент.
|
|
33
|
+
*/
|
|
34
|
+
protected readonly context: TuiDialogContext<ScContragent, void>;
|
|
17
35
|
/**
|
|
18
36
|
* Перечисление организационно-правовых форм.
|
|
19
37
|
*/
|
|
@@ -44,17 +62,6 @@ export declare class ScAddContragentDialogComponent implements AfterViewInit {
|
|
|
44
62
|
* {@link Observable} изменения состояния загрузки данных аутентификации по номеру телефона.
|
|
45
63
|
*/
|
|
46
64
|
readonly loading$: Observable<boolean>;
|
|
47
|
-
/**
|
|
48
|
-
* Инициализирует экземпляр класса {@link ScAddContragentDialogComponent}.
|
|
49
|
-
*
|
|
50
|
-
* @param referencesService Сервис справочников.
|
|
51
|
-
* @param contragentService Сервис работы с контрагентами.
|
|
52
|
-
* @param convertersService Сервис конвертации данных.
|
|
53
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
|
54
|
-
* @param locationsService Сервис для получения списков стран, регионов, городов.
|
|
55
|
-
* @param context Контекст диалогового окна, в котором открыт компонент.
|
|
56
|
-
*/
|
|
57
|
-
constructor(referencesService: ScReferencesService, contragentService: ScContragentService, convertersService: ScConvertersService, userMetrikaService: ScUserMetrikaService, locationsService: ScLocationsService, context: TuiDialogContext<ScContragent, void>);
|
|
58
65
|
/** @inheritdoc */
|
|
59
66
|
ngAfterViewInit(): void;
|
|
60
67
|
/**
|
|
@@ -83,16 +90,6 @@ export declare class ScAddContragentDialogComponent implements AfterViewInit {
|
|
|
83
90
|
* @returns Выводит значение `boolean` на основании {@link index}.
|
|
84
91
|
*/
|
|
85
92
|
canNextStep(index: number): boolean;
|
|
86
|
-
/**
|
|
87
|
-
* Возвращает {@link Observable} списка направлений продаж.
|
|
88
|
-
*/
|
|
89
|
-
getSalesDirections$(): Observable<ScISalesDirection[]>;
|
|
90
|
-
/**
|
|
91
|
-
* Возвращает {@link Observable} списка направлений продаж.
|
|
92
|
-
*
|
|
93
|
-
* @param directionId Идентификатор направления продаж.
|
|
94
|
-
*/
|
|
95
|
-
getDirectionById$(directionId: number): Observable<ScISalesDirection | undefined>;
|
|
96
93
|
/**
|
|
97
94
|
* Возвращает {@link Observable} список организационно-правовых форм.
|
|
98
95
|
*/
|
|
@@ -156,6 +153,6 @@ export declare class ScAddContragentDialogComponent implements AfterViewInit {
|
|
|
156
153
|
* @param index Индекс контактного лица.
|
|
157
154
|
*/
|
|
158
155
|
removeContactGroup(index: number): void;
|
|
159
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddContragentDialogComponent,
|
|
156
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ScAddContragentDialogComponent, never>;
|
|
160
157
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScAddContragentDialogComponent, "sc-add-contragent-dialog", never, {}, {}, never, never, false, never>;
|
|
161
158
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnDestroy, OnInit } from '@angular/core';
|
|
2
|
-
import { FormArray, FormControl, FormGroup
|
|
3
|
-
import { ScICountry, ScIReferencesTypes,
|
|
2
|
+
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
|
+
import { ScICountry, ScIReferencesTypes, ScISuggestionType, ScOpfList } from '@snabcentr/client-core';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
5
|
import { ScContactFormGroup } from '../../auth/interfaces';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -8,8 +8,17 @@ import * as i0 from "@angular/core";
|
|
|
8
8
|
* Форма создания нового контрагента.
|
|
9
9
|
*/
|
|
10
10
|
export declare class ScNewContragentFormComponent implements OnInit, OnDestroy {
|
|
11
|
+
/**
|
|
12
|
+
* Сервис справочников.
|
|
13
|
+
*/
|
|
11
14
|
private readonly referencesService;
|
|
15
|
+
/**
|
|
16
|
+
* Сервис для получения списков стран, регионов, городов.
|
|
17
|
+
*/
|
|
12
18
|
private readonly locationsService;
|
|
19
|
+
/**
|
|
20
|
+
* Директива c `FormGroup` из DOM.
|
|
21
|
+
*/
|
|
13
22
|
private readonly formGroupDirective;
|
|
14
23
|
/**
|
|
15
24
|
* Поле выбора организационно-правовой формы.
|
|
@@ -33,7 +42,6 @@ export declare class ScNewContragentFormComponent implements OnInit, OnDestroy {
|
|
|
33
42
|
readonly form: FormGroup<{
|
|
34
43
|
name: FormControl<string | null>;
|
|
35
44
|
opf: FormControl<"individual" | "entrepreneur" | "legal" | "non_resident_legal" | null>;
|
|
36
|
-
salesDirectionId: FormControl<number | null>;
|
|
37
45
|
contacts: FormArray<ScContactFormGroup>;
|
|
38
46
|
}>;
|
|
39
47
|
/**
|
|
@@ -82,14 +90,6 @@ export declare class ScNewContragentFormComponent implements OnInit, OnDestroy {
|
|
|
82
90
|
* @param items Список стран.
|
|
83
91
|
*/
|
|
84
92
|
protected readonly stringify: (items: readonly ScICountry[]) => (id: number) => string;
|
|
85
|
-
/**
|
|
86
|
-
* Инициализирует экземпляр класса {@link ScNewContragentFormComponent}.
|
|
87
|
-
*
|
|
88
|
-
* @param referencesService Сервис справочников.
|
|
89
|
-
* @param locationsService Сервис для получения списков стран, регионов, городов.
|
|
90
|
-
* @param formGroupDirective Директива c `FormGroup` из DOM.
|
|
91
|
-
*/
|
|
92
|
-
constructor(referencesService: ScReferencesService, locationsService: ScLocationsService, formGroupDirective: FormGroupDirective | null);
|
|
93
93
|
/**
|
|
94
94
|
* Родительская `FormGroup`.
|
|
95
95
|
*/
|
|
@@ -98,12 +98,6 @@ export declare class ScNewContragentFormComponent implements OnInit, OnDestroy {
|
|
|
98
98
|
ngOnInit(): void;
|
|
99
99
|
/** @inheritDoc */
|
|
100
100
|
ngOnDestroy(): void;
|
|
101
|
-
/**
|
|
102
|
-
* Возвращает {@link Observable} списка направлений продаж.
|
|
103
|
-
*
|
|
104
|
-
* @param directionId Идентификатор направления продаж.
|
|
105
|
-
*/
|
|
106
|
-
protected getDirectionById$(directionId: number): Observable<ScISalesDirection | undefined>;
|
|
107
101
|
/**
|
|
108
102
|
* Возвращает {@link Observable} список организационно-правовых форм..
|
|
109
103
|
*/
|
|
@@ -120,6 +114,6 @@ export declare class ScNewContragentFormComponent implements OnInit, OnDestroy {
|
|
|
120
114
|
* @param countryId — Идентификатор страны.
|
|
121
115
|
*/
|
|
122
116
|
protected getCountryNameById$(countryId: number): Observable<string | undefined>;
|
|
123
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<ScNewContragentFormComponent,
|
|
117
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ScNewContragentFormComponent, never>;
|
|
124
118
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScNewContragentFormComponent, "sc-new-contragent-form", never, { "opfControl": { "alias": "opfControl"; "required": false; }; }, {}, never, never, false, never>;
|
|
125
119
|
}
|
|
@@ -179,7 +179,6 @@ export class ScSimpleSignUpFormComponent {
|
|
|
179
179
|
formValue.contragent = {
|
|
180
180
|
name: this.form.controls.name.value,
|
|
181
181
|
opf: 'individual',
|
|
182
|
-
salesDirectionId: 1,
|
|
183
182
|
contacts: [
|
|
184
183
|
{
|
|
185
184
|
name: this.form.controls.name.value,
|
|
@@ -200,4 +199,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
|
|
|
200
199
|
type: Component,
|
|
201
200
|
args: [{ selector: 'sc-simple-sign-up-form', providers: [tuiDropdownOptionsProvider({ limitWidth: 'fixed' })], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form\n [formGroup]=\"form\"\n (ngSubmit)=\"onSubmit$.next()\"\n class=\"flex flex-col gap-6\"\n>\n <div class=\"flex flex-col gap-3\">\n <sc-verification-phone-check-form\n (isBusyChange)=\"onIsBusyChange($event)\"\n (isConfirmedChange)=\"onIsConfirmedChange($event)\"\n [showCodeFields]=\"form.controls.phone.valid && form.controls.phone.valid\"\n [shouldBeConfirmed]=\"true\"\n />\n @if (isPhoneBusy() !== null && form.controls.phone.valid) {\n @if (!isPhoneBusy()) {\n <label tuiLabel>\n \u0424.\u0418.\u041E.\n <tui-input formControlName=\"name\">\n \u0424.\u0418.\u041E.\n <input\n tuiTextfieldLegacy\n autocomplete=\"name\"\n />\n </tui-input>\n <tui-error\n formControlName=\"name\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n\n <label tuiLabel>\n \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 \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 />\n </tui-input>\n <tui-error\n formControlName=\"email\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </label>\n\n <tui-error\n [error]=\"[] | tuiFieldError | async\"\n class=\"self-center\"\n />\n\n <label tuiLabel>\n <input\n tuiCheckbox\n type=\"checkbox\"\n formControlName=\"getNews\"\n />\n \u042F \u0445\u043E\u0447\u0443 \u043F\u043E\u043B\u0443\u0447\u0430\u0442\u044C \u0440\u0430\u0441\u0441\u044B\u043B\u043A\u0443 \u0421\u043D\u0430\u0431\u0446\u0435\u043D\u0442\u0440 \u043E \u0441\u043A\u0438\u0434\u043A\u0430\u0445 \u0438 \u043D\u043E\u0432\u043E\u0441\u0442\u044F\u0445 \u043F\u043E \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u0435.\n </label>\n\n <label tuiLabel>\n <input\n tuiCheckbox\n type=\"checkbox\"\n required=\"true\"\n formControlName=\"acceptRules\"\n />\n <div>\n <span>\n \u0420\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u0443\u044F\u0441\u044C \u043D\u0430 \u0441\u0430\u0439\u0442\u0435, \u044F \u0441\u043E\u0433\u043B\u0430\u0448\u0430\u044E\u0441\u044C \u0441\n <a\n tuiLink\n [pseudo]=\"true\"\n (click)=\"$event.preventDefault(); clickOffer.emit()\"\n >\n \u0414\u043E\u0433\u043E\u0432\u043E\u0440\u043E\u043C \u043E\u0444\u0435\u0440\u0442\u044B\n </a>\n .\n </span>\n <span class=\"text-tui-negative\">*</span>\n <tui-error\n formControlName=\"acceptRules\"\n [error]=\"[] | tuiFieldError | async\"\n />\n </div>\n </label>\n }\n }\n\n <tui-error\n [error]=\"[] | tuiFieldError | async\"\n class=\"self-center\"\n />\n </div>\n <button\n tuiButton\n [disabled]=\"isPhoneBusy() ? form.controls.verificationCode.invalid || form.controls.phone.invalid : form.invalid\"\n [loading]=\"loading()\"\n type=\"submit\"\n class=\"self-center\"\n >\n {{ isPhoneBusy() ? '\u0412\u043E\u0439\u0442\u0438' : '\u041A\u0443\u043F\u0438\u0442\u044C' }}\n </button>\n</form>\n" }]
|
|
202
201
|
}] });
|
|
203
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-simple-sign-up-form.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.ts","../../../../../projects/client-ui/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any,no-param-reassign,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, inject, OnDestroy, OnInit, output, OutputEmitterRef, OutputRef, Signal, signal } from '@angular/core';\nimport { outputFromObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    IAuthToken,\n    ScAuthService,\n    ScConvertersService,\n    ScIOrgContact,\n    ScISimpleUserOnDataCreate,\n    ScISuggestionType,\n    ScUser,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n    ScUserService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy } from '@taiga-ui/cdk';\nimport { tuiDropdownOptionsProvider } from '@taiga-ui/core';\nimport { catchError, filter, map, of, share, startWith, Subject, switchMap, throwError } from 'rxjs';\n\nimport { ScHelpNotificationService } from '../../services';\nimport { phoneValidator } from '../../validators/sc-phone-validator';\nimport { ApiErrorResponse } from '../interfaces/api-error-response';\n\n/**\n * Компонент упрощенной регистрации.\n */\n@Component({\n    selector: 'sc-simple-sign-up-form',\n    templateUrl: './sc-simple-sign-up-form.component.html',\n    providers: [tuiDropdownOptionsProvider({ limitWidth: 'fixed' })],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSimpleSignUpFormComponent implements OnInit, OnDestroy {\n    /**\n     * Сервис данных о пользователе.\n     */\n    private readonly userService = inject(ScUserService);\n\n    /**\n     * Сервис аутентификации.\n     */\n    private readonly authService = inject(ScAuthService);\n\n    /**\n     * Сервис конвертации данных.\n     */\n    private readonly convertersService = inject(ScConvertersService);\n\n    /**\n     * Сервис для сбора метрик о действиях пользователей.\n     */\n    private readonly userMetrikaService = inject(ScUserMetrikaService);\n\n    /**\n     * Группа полей ввода для формы регистрации.\n     */\n    protected readonly form = new FormGroup({\n        name: new FormControl<string | null>(null, [Validators.required, Validators.minLength(3)]),\n        email: new FormControl<string | null>(null, [Validators.required, Validators.email]),\n        phone: new FormControl<string | null>(null, [Validators.required, phoneValidator()]),\n        verificationCode: new FormControl<string | null>(null, [Validators.required, Validators.minLength(6)]),\n        getNews: new FormControl<boolean>(false),\n        acceptRules: new FormControl<boolean>(false, Validators.requiredTrue),\n        contragent: new FormGroup<any>({}),\n    });\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    protected readonly showCodeFields = signal(false);\n\n    /**\n     * Признак, занят ли телефон (существует ли пользователь с таким телефоном).\n     */\n    protected readonly isPhoneBusy = signal<boolean | null>(null);\n\n    /**\n     * Признак, нужно ли отображать дополнительные поля для регистрации.\n     */\n    protected readonly showAdditionalFields = signal(false);\n\n    /**\n     * Список контактов для отправки push-уведомлений.\n     */\n    protected readonly pushContacts: Signal<ScIOrgContact[] | undefined> = toSignal(inject(ScHelpNotificationService).getContactsShow$());\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    protected readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    protected 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 ScISimpleUserOnDataCreate => (this.isPhoneBusy() ? this.form.controls.verificationCode.valid : this.form.valid)),\n        switchMap((value) => {\n            if (this.isPhoneBusy()) {\n                return this.authService.getSignIn$({ phone: value.phone, verificationCode: value.verificationCode }).pipe(\n                    catchError((error: unknown) => {\n                        if (error instanceof HttpErrorResponse) {\n                            const { message } = error.error as ApiErrorResponse;\n\n                            if (message.includes('деактивирован')) {\n                                this.helpNotificationService.helpNotificationByPhone(value.phone);\n                            }\n                        }\n\n                        return throwError(() => error);\n                    }),\n                    catchError((error: unknown) => {\n                        this.handleError(error);\n\n                        return of({} as IAuthToken);\n                    }),\n                    startWith(null)\n                );\n            }\n\n            this.createBaseContragent(value);\n            value.isGeneratePassword = true;\n            value.isUnknownCity = true;\n\n            return this.userService.signUp$(this.convertersService.removeNullRecursive(value)).pipe(\n                catchError((error: unknown) => {\n                    this.handleError(error);\n\n                    return of({} as IAuthToken);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * Сигнал изменения состояния загрузки данных.\n     */\n    protected readonly loading: Signal<boolean> = toSignal(this.request$.pipe(map(tuiIsFalsy)), { initialValue: false });\n\n    /**\n     * Сигнал события аутентификации после успешной регистрации.\n     */\n    public readonly successAuth: OutputRef<ScUser> = outputFromObservable(this.userService.getUserChange$().pipe(filter((user) => !user.isGuest)));\n\n    /**\n     * Сервис для отображения Push-уведомлений с контактами для помощи клиенту.\n     */\n    protected readonly helpNotificationService: ScHelpNotificationService = inject(ScHelpNotificationService);\n\n    /**\n     * Сигнал нажатия на \"Договор оферты\".\n     */\n    public readonly clickOffer: OutputEmitterRef<void> = output();\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.simpleSsignUpShow,\n        });\n    }\n\n    /**\n     * Обрабатывает событие изменения занятости телефона.\n     *\n     * @param isBusy Признак занятости телефона.\n     */\n    protected onIsBusyChange(isBusy: boolean | null): void {\n        this.isPhoneBusy.set(isBusy);\n        this.showCodeFields.set(isBusy !== null);\n        this.showAdditionalFields.set(!isBusy);\n    }\n\n    /**\n     * Обрабатывает событие изменения подтверждения телефона.\n     *\n     * @param isConfirmed Признак подтверждения телефона.\n     */\n    protected onIsConfirmedChange(isConfirmed: boolean | null): void {\n        if (isConfirmed === false) {\n            this.form.controls.phone.setErrors({\n                serverResponse: ['Номер телефона не подтверждён. Обратитесь к вашему персональному менеджеру или войдите с использованием e-mail и пароля.'],\n            });\n\n            this.form.controls.phone.markAsTouched();\n        }\n    }\n\n    /**\n     * Обрабатывает ошибки запросов.\n     *\n     * @param error Объект ошибки\n     */\n    private handleError(error: unknown): void {\n        if (error instanceof HttpErrorResponse) {\n            const { errors, message } = error.error as ApiErrorResponse;\n\n            // eslint-disable-next-line guard-for-in,no-restricted-syntax\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    }\n\n    /**\n     * Создаёт базового контрагента для клиента физического лица.\n     *\n     * @param formValue Значение формы при регистрации\n     */\n    private createBaseContragent(formValue: ScSimpleSignUpFormComponent['form']['value']): void {\n        if (this.form.invalid) {\n            return;\n        }\n\n        formValue.contragent = {\n            name: this.form.controls.name.value,\n            opf: 'individual',\n            salesDirectionId: 1,\n            contacts: [\n                {\n                    name: this.form.controls.name.value,\n                    phone: this.form.controls.phone.value,\n                    email: this.form.controls.email.value,\n                },\n            ],\n        };\n    }\n\n    /** @inheritDoc */\n    public ngOnDestroy(): void {\n        this.helpNotificationService.closeAllHelpNotification();\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit$.next()\"\n    class=\"flex flex-col gap-6\"\n>\n    <div class=\"flex flex-col gap-3\">\n        <sc-verification-phone-check-form\n            (isBusyChange)=\"onIsBusyChange($event)\"\n            (isConfirmedChange)=\"onIsConfirmedChange($event)\"\n            [showCodeFields]=\"form.controls.phone.valid && form.controls.phone.valid\"\n            [shouldBeConfirmed]=\"true\"\n        />\n        @if (isPhoneBusy() !== null && form.controls.phone.valid) {\n            @if (!isPhoneBusy()) {\n                <label tuiLabel>\n                    Ф.И.О.\n                    <tui-input formControlName=\"name\">\n                        Ф.И.О.\n                        <input\n                            tuiTextfieldLegacy\n                            autocomplete=\"name\"\n                        />\n                    </tui-input>\n                    <tui-error\n                        formControlName=\"name\"\n                        [error]=\"[] | tuiFieldError | async\"\n                    />\n                </label>\n\n                <label tuiLabel>\n                    Адрес электронной почты\n                    <tui-input formControlName=\"email\">\n                        Адрес электронной почты\n                        <sc-suggestion-field\n                            *tuiDataList\n                            [type]=\"suggestionType.email\"\n                        />\n                    </tui-input>\n                    <tui-error\n                        formControlName=\"email\"\n                        [error]=\"[] | tuiFieldError | async\"\n                    />\n                </label>\n\n                <tui-error\n                    [error]=\"[] | tuiFieldError | async\"\n                    class=\"self-center\"\n                />\n\n                <label tuiLabel>\n                    <input\n                        tuiCheckbox\n                        type=\"checkbox\"\n                        formControlName=\"getNews\"\n                    />\n                    Я хочу получать рассылку Снабцентр о скидках и новостях по электронной почте.\n                </label>\n\n                <label tuiLabel>\n                    <input\n                        tuiCheckbox\n                        type=\"checkbox\"\n                        required=\"true\"\n                        formControlName=\"acceptRules\"\n                    />\n                    <div>\n                        <span>\n                            Регистрируясь на сайте, я соглашаюсь с\n                            <a\n                                tuiLink\n                                [pseudo]=\"true\"\n                                (click)=\"$event.preventDefault(); clickOffer.emit()\"\n                            >\n                                Договором оферты\n                            </a>\n                            .\n                        </span>\n                        <span class=\"text-tui-negative\">*</span>\n                        <tui-error\n                            formControlName=\"acceptRules\"\n                            [error]=\"[] | tuiFieldError | async\"\n                        />\n                    </div>\n                </label>\n            }\n        }\n\n        <tui-error\n            [error]=\"[] | tuiFieldError | async\"\n            class=\"self-center\"\n        />\n    </div>\n    <button\n        tuiButton\n        [disabled]=\"isPhoneBusy() ? form.controls.verificationCode.invalid || form.controls.phone.invalid : form.invalid\"\n        [loading]=\"loading()\"\n        type=\"submit\"\n        class=\"self-center\"\n    >\n        {{ isPhoneBusy() ? 'Войти' : 'Купить' }}\n    </button>\n</form>\n"]}
|
|
202
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-simple-sign-up-form.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.ts","../../../../../projects/client-ui/auth/sc-simple-sign-up-form/sc-simple-sign-up-form.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any,no-param-reassign,@typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, inject, OnDestroy, OnInit, output, OutputEmitterRef, OutputRef, Signal, signal } from '@angular/core';\nimport { outputFromObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport {\n    IAuthToken,\n    ScAuthService,\n    ScConvertersService,\n    ScIOrgContact,\n    ScISimpleUserOnDataCreate,\n    ScISuggestionType,\n    ScUser,\n    ScUserMetrikaGoalsEnum,\n    ScUserMetrikaService,\n    ScUserService,\n} from '@snabcentr/client-core';\nimport { tuiIsFalsy } from '@taiga-ui/cdk';\nimport { tuiDropdownOptionsProvider } from '@taiga-ui/core';\nimport { catchError, filter, map, of, share, startWith, Subject, switchMap, throwError } from 'rxjs';\n\nimport { ScHelpNotificationService } from '../../services';\nimport { phoneValidator } from '../../validators/sc-phone-validator';\nimport { ApiErrorResponse } from '../interfaces/api-error-response';\n\n/**\n * Компонент упрощенной регистрации.\n */\n@Component({\n    selector: 'sc-simple-sign-up-form',\n    templateUrl: './sc-simple-sign-up-form.component.html',\n    providers: [tuiDropdownOptionsProvider({ limitWidth: 'fixed' })],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSimpleSignUpFormComponent implements OnInit, OnDestroy {\n    /**\n     * Сервис данных о пользователе.\n     */\n    private readonly userService = inject(ScUserService);\n\n    /**\n     * Сервис аутентификации.\n     */\n    private readonly authService = inject(ScAuthService);\n\n    /**\n     * Сервис конвертации данных.\n     */\n    private readonly convertersService = inject(ScConvertersService);\n\n    /**\n     * Сервис для сбора метрик о действиях пользователей.\n     */\n    private readonly userMetrikaService = inject(ScUserMetrikaService);\n\n    /**\n     * Группа полей ввода для формы регистрации.\n     */\n    protected readonly form = new FormGroup({\n        name: new FormControl<string | null>(null, [Validators.required, Validators.minLength(3)]),\n        email: new FormControl<string | null>(null, [Validators.required, Validators.email]),\n        phone: new FormControl<string | null>(null, [Validators.required, phoneValidator()]),\n        verificationCode: new FormControl<string | null>(null, [Validators.required, Validators.minLength(6)]),\n        getNews: new FormControl<boolean>(false),\n        acceptRules: new FormControl<boolean>(false, Validators.requiredTrue),\n        contragent: new FormGroup<any>({}),\n    });\n\n    /**\n     * Признак, следует ли отображать функционал кода подтверждения.\n     */\n    protected readonly showCodeFields = signal(false);\n\n    /**\n     * Признак, занят ли телефон (существует ли пользователь с таким телефоном).\n     */\n    protected readonly isPhoneBusy = signal<boolean | null>(null);\n\n    /**\n     * Признак, нужно ли отображать дополнительные поля для регистрации.\n     */\n    protected readonly showAdditionalFields = signal(false);\n\n    /**\n     * Список контактов для отправки push-уведомлений.\n     */\n    protected readonly pushContacts: Signal<ScIOrgContact[] | undefined> = toSignal(inject(ScHelpNotificationService).getContactsShow$());\n\n    /**\n     * Перечисление типов подсказок.\n     */\n    protected readonly suggestionType: typeof ScISuggestionType = ScISuggestionType;\n\n    /**\n     * {@link Subject} события отправки формы.\n     */\n    protected 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 ScISimpleUserOnDataCreate => (this.isPhoneBusy() ? this.form.controls.verificationCode.valid : this.form.valid)),\n        switchMap((value) => {\n            if (this.isPhoneBusy()) {\n                return this.authService.getSignIn$({ phone: value.phone, verificationCode: value.verificationCode }).pipe(\n                    catchError((error: unknown) => {\n                        if (error instanceof HttpErrorResponse) {\n                            const { message } = error.error as ApiErrorResponse;\n\n                            if (message.includes('деактивирован')) {\n                                this.helpNotificationService.helpNotificationByPhone(value.phone);\n                            }\n                        }\n\n                        return throwError(() => error);\n                    }),\n                    catchError((error: unknown) => {\n                        this.handleError(error);\n\n                        return of({} as IAuthToken);\n                    }),\n                    startWith(null)\n                );\n            }\n\n            this.createBaseContragent(value);\n            value.isGeneratePassword = true;\n            value.isUnknownCity = true;\n\n            return this.userService.signUp$(this.convertersService.removeNullRecursive(value)).pipe(\n                catchError((error: unknown) => {\n                    this.handleError(error);\n\n                    return of({} as IAuthToken);\n                }),\n                startWith(null)\n            );\n        }),\n        share()\n    );\n\n    /**\n     * Сигнал изменения состояния загрузки данных.\n     */\n    protected readonly loading: Signal<boolean> = toSignal(this.request$.pipe(map(tuiIsFalsy)), { initialValue: false });\n\n    /**\n     * Сигнал события аутентификации после успешной регистрации.\n     */\n    public readonly successAuth: OutputRef<ScUser> = outputFromObservable(this.userService.getUserChange$().pipe(filter((user) => !user.isGuest)));\n\n    /**\n     * Сервис для отображения Push-уведомлений с контактами для помощи клиенту.\n     */\n    protected readonly helpNotificationService: ScHelpNotificationService = inject(ScHelpNotificationService);\n\n    /**\n     * Сигнал нажатия на \"Договор оферты\".\n     */\n    public readonly clickOffer: OutputEmitterRef<void> = output();\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.simpleSsignUpShow,\n        });\n    }\n\n    /**\n     * Обрабатывает событие изменения занятости телефона.\n     *\n     * @param isBusy Признак занятости телефона.\n     */\n    protected onIsBusyChange(isBusy: boolean | null): void {\n        this.isPhoneBusy.set(isBusy);\n        this.showCodeFields.set(isBusy !== null);\n        this.showAdditionalFields.set(!isBusy);\n    }\n\n    /**\n     * Обрабатывает событие изменения подтверждения телефона.\n     *\n     * @param isConfirmed Признак подтверждения телефона.\n     */\n    protected onIsConfirmedChange(isConfirmed: boolean | null): void {\n        if (isConfirmed === false) {\n            this.form.controls.phone.setErrors({\n                serverResponse: ['Номер телефона не подтверждён. Обратитесь к вашему персональному менеджеру или войдите с использованием e-mail и пароля.'],\n            });\n\n            this.form.controls.phone.markAsTouched();\n        }\n    }\n\n    /**\n     * Обрабатывает ошибки запросов.\n     *\n     * @param error Объект ошибки\n     */\n    private handleError(error: unknown): void {\n        if (error instanceof HttpErrorResponse) {\n            const { errors, message } = error.error as ApiErrorResponse;\n\n            // eslint-disable-next-line guard-for-in,no-restricted-syntax\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    }\n\n    /**\n     * Создаёт базового контрагента для клиента физического лица.\n     *\n     * @param formValue Значение формы при регистрации\n     */\n    private createBaseContragent(formValue: ScSimpleSignUpFormComponent['form']['value']): void {\n        if (this.form.invalid) {\n            return;\n        }\n\n        formValue.contragent = {\n            name: this.form.controls.name.value,\n            opf: 'individual',\n            contacts: [\n                {\n                    name: this.form.controls.name.value,\n                    phone: this.form.controls.phone.value,\n                    email: this.form.controls.email.value,\n                },\n            ],\n        };\n    }\n\n    /** @inheritDoc */\n    public ngOnDestroy(): void {\n        this.helpNotificationService.closeAllHelpNotification();\n    }\n}\n","<form\n    [formGroup]=\"form\"\n    (ngSubmit)=\"onSubmit$.next()\"\n    class=\"flex flex-col gap-6\"\n>\n    <div class=\"flex flex-col gap-3\">\n        <sc-verification-phone-check-form\n            (isBusyChange)=\"onIsBusyChange($event)\"\n            (isConfirmedChange)=\"onIsConfirmedChange($event)\"\n            [showCodeFields]=\"form.controls.phone.valid && form.controls.phone.valid\"\n            [shouldBeConfirmed]=\"true\"\n        />\n        @if (isPhoneBusy() !== null && form.controls.phone.valid) {\n            @if (!isPhoneBusy()) {\n                <label tuiLabel>\n                    Ф.И.О.\n                    <tui-input formControlName=\"name\">\n                        Ф.И.О.\n                        <input\n                            tuiTextfieldLegacy\n                            autocomplete=\"name\"\n                        />\n                    </tui-input>\n                    <tui-error\n                        formControlName=\"name\"\n                        [error]=\"[] | tuiFieldError | async\"\n                    />\n                </label>\n\n                <label tuiLabel>\n                    Адрес электронной почты\n                    <tui-input formControlName=\"email\">\n                        Адрес электронной почты\n                        <sc-suggestion-field\n                            *tuiDataList\n                            [type]=\"suggestionType.email\"\n                        />\n                    </tui-input>\n                    <tui-error\n                        formControlName=\"email\"\n                        [error]=\"[] | tuiFieldError | async\"\n                    />\n                </label>\n\n                <tui-error\n                    [error]=\"[] | tuiFieldError | async\"\n                    class=\"self-center\"\n                />\n\n                <label tuiLabel>\n                    <input\n                        tuiCheckbox\n                        type=\"checkbox\"\n                        formControlName=\"getNews\"\n                    />\n                    Я хочу получать рассылку Снабцентр о скидках и новостях по электронной почте.\n                </label>\n\n                <label tuiLabel>\n                    <input\n                        tuiCheckbox\n                        type=\"checkbox\"\n                        required=\"true\"\n                        formControlName=\"acceptRules\"\n                    />\n                    <div>\n                        <span>\n                            Регистрируясь на сайте, я соглашаюсь с\n                            <a\n                                tuiLink\n                                [pseudo]=\"true\"\n                                (click)=\"$event.preventDefault(); clickOffer.emit()\"\n                            >\n                                Договором оферты\n                            </a>\n                            .\n                        </span>\n                        <span class=\"text-tui-negative\">*</span>\n                        <tui-error\n                            formControlName=\"acceptRules\"\n                            [error]=\"[] | tuiFieldError | async\"\n                        />\n                    </div>\n                </label>\n            }\n        }\n\n        <tui-error\n            [error]=\"[] | tuiFieldError | async\"\n            class=\"self-center\"\n        />\n    </div>\n    <button\n        tuiButton\n        [disabled]=\"isPhoneBusy() ? form.controls.verificationCode.invalid || form.controls.phone.invalid : form.invalid\"\n        [loading]=\"loading()\"\n        type=\"submit\"\n        class=\"self-center\"\n    >\n        {{ isPhoneBusy() ? 'Войти' : 'Купить' }}\n    </button>\n</form>\n"]}
|