@snabcentr/client-ui 0.17.4 → 0.19.0
Sign up to get free protection for your applications and to get access to all the features.
- package/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.d.ts +4 -8
- package/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.d.ts +3 -8
- package/auth/sc-sign-in-form/sc-sign-in-form.component.d.ts +8 -4
- package/catalog/price-history/sc-price-history.component.d.ts +44 -43
- package/catalog/sc-catalog.module.d.ts +3 -3
- package/esm2020/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.mjs +4 -16
- package/esm2020/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.mjs +4 -16
- package/esm2020/auth/sc-sign-in-form/sc-sign-in-form.component.mjs +24 -6
- package/esm2020/banner/sc-banner.component.mjs +4 -2
- package/esm2020/catalog/price-history/sc-price-history.component.mjs +85 -79
- package/esm2020/catalog/sc-catalog.module.mjs +12 -15
- package/fesm2015/snabcentr-client-ui.mjs +125 -321
- package/fesm2015/snabcentr-client-ui.mjs.map +1 -1
- package/fesm2020/snabcentr-client-ui.mjs +123 -320
- package/fesm2020/snabcentr-client-ui.mjs.map +1 -1
- package/package.json +3 -5
- package/styles/tailwind/tailwind.scss +0 -24
- package/catalog/price-history/sc-chart-option.d.ts +0 -7
- package/catalog/price-history/sc-i-chart-data-item.d.ts +0 -13
- package/catalog/price-history/sc-lang-ru.d.ts +0 -115
- package/esm2020/catalog/price-history/sc-chart-option.mjs +0 -79
- package/esm2020/catalog/price-history/sc-i-chart-data-item.mjs +0 -2
- package/esm2020/catalog/price-history/sc-lang-ru.mjs +0 -115
package/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.d.ts
CHANGED
@@ -1,14 +1,13 @@
|
|
1
|
-
import { EventEmitter
|
1
|
+
import { EventEmitter } from '@angular/core';
|
2
2
|
import { FormGroup } from '@angular/forms';
|
3
|
-
import { ScAuthService
|
3
|
+
import { ScAuthService } from '@snabcentr/client-core';
|
4
4
|
import { Observable, Subject } from 'rxjs';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
/**
|
7
7
|
* Компонент аутентификации по адресу электронной почты и паролю.
|
8
8
|
*/
|
9
|
-
export declare class ScSignInFormByEmailComponent
|
9
|
+
export declare class ScSignInFormByEmailComponent {
|
10
10
|
private readonly authService;
|
11
|
-
private readonly userMetrikaService;
|
12
11
|
/**
|
13
12
|
* Группа полей ввода для формы «Вход на сайт».
|
14
13
|
*/
|
@@ -33,11 +32,8 @@ export declare class ScSignInFormByEmailComponent implements OnInit {
|
|
33
32
|
* Инициализирует экземпляр класса {@link ScSignInFormByEmailComponent}.
|
34
33
|
*
|
35
34
|
* @param authService Сервис аутентификации.
|
36
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
37
35
|
*/
|
38
|
-
constructor(authService: ScAuthService
|
39
|
-
/** @inheritDoc */
|
40
|
-
ngOnInit(): void;
|
36
|
+
constructor(authService: ScAuthService);
|
41
37
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScSignInFormByEmailComponent, never>;
|
42
38
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScSignInFormByEmailComponent, "sc-sign-in-form-by-email", never, {}, { "forgotPassword": "forgotPassword"; }, never, never, false>;
|
43
39
|
}
|
package/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.d.ts
CHANGED
@@ -1,14 +1,12 @@
|
|
1
|
-
import { OnInit } from '@angular/core';
|
2
1
|
import { FormControl, FormGroup } from '@angular/forms';
|
3
|
-
import { ScAuthService
|
2
|
+
import { ScAuthService } from '@snabcentr/client-core';
|
4
3
|
import { Observable, Subject } from 'rxjs';
|
5
4
|
import * as i0 from "@angular/core";
|
6
5
|
/**
|
7
6
|
* Компонент аутентификации по номеру телефона и коду подтверждения.
|
8
7
|
*/
|
9
|
-
export declare class ScSignInFormByPhoneComponent
|
8
|
+
export declare class ScSignInFormByPhoneComponent {
|
10
9
|
private readonly authService;
|
11
|
-
private readonly userMetrikaService;
|
12
10
|
/**
|
13
11
|
* Наличие кода подтверждения у пользователя.
|
14
12
|
*/
|
@@ -36,11 +34,8 @@ export declare class ScSignInFormByPhoneComponent implements OnInit {
|
|
36
34
|
* Инициализирует экземпляр класса {@link ScSignInFormByPhoneComponent}.
|
37
35
|
*
|
38
36
|
* @param authService Сервис аутентификации.
|
39
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
40
37
|
*/
|
41
|
-
constructor(authService: ScAuthService
|
42
|
-
/** @inheritDoc */
|
43
|
-
ngOnInit(): void;
|
38
|
+
constructor(authService: ScAuthService);
|
44
39
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScSignInFormByPhoneComponent, never>;
|
45
40
|
static ɵcmp: i0.ɵɵComponentDeclaration<ScSignInFormByPhoneComponent, "sc-sign-in-form-by-phone", never, {}, {}, never, never, false>;
|
46
41
|
}
|
@@ -1,13 +1,14 @@
|
|
1
|
-
import { EventEmitter } from '@angular/core';
|
2
|
-
import { ScAuthService } from '@snabcentr/client-core';
|
1
|
+
import { EventEmitter, OnInit } from '@angular/core';
|
2
|
+
import { ScAuthService, ScUserMetrikaService } from '@snabcentr/client-core';
|
3
3
|
import { Observable } from 'rxjs';
|
4
4
|
import { AuthMethod } from '../enums/auth-method';
|
5
5
|
import * as i0 from "@angular/core";
|
6
6
|
/**
|
7
7
|
* Компонент аутентификации пользователя.
|
8
8
|
*/
|
9
|
-
export declare class ScSignInFormComponent {
|
9
|
+
export declare class ScSignInFormComponent implements OnInit {
|
10
10
|
private readonly authService;
|
11
|
+
private readonly userMetrikaService;
|
11
12
|
/**
|
12
13
|
* Выбранный способ аутентификации.
|
13
14
|
*/
|
@@ -32,8 +33,11 @@ export declare class ScSignInFormComponent {
|
|
32
33
|
* Инициализирует экземпляр класса {@link ScSignInFormComponent}.
|
33
34
|
*
|
34
35
|
* @param authService Сервис аутентификации.
|
36
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
35
37
|
*/
|
36
|
-
constructor(authService: ScAuthService);
|
38
|
+
constructor(authService: ScAuthService, userMetrikaService: ScUserMetrikaService);
|
39
|
+
/** @inheritDoc */
|
40
|
+
ngOnInit(): void;
|
37
41
|
/**
|
38
42
|
* Осуществляет переключение способов аутентификации.
|
39
43
|
*
|
@@ -1,73 +1,74 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
3
|
-
import {
|
1
|
+
import { OnInit } from '@angular/core';
|
2
|
+
import { ScCatalogService, ScProduct } from '@snabcentr/client-core';
|
3
|
+
import { TuiDay, TuiDayRange, TuiStringHandler } from '@taiga-ui/cdk';
|
4
|
+
import { TuiDialogContext } from '@taiga-ui/core';
|
5
|
+
import { Observable } from 'rxjs';
|
4
6
|
import * as i0 from "@angular/core";
|
5
7
|
/**
|
6
8
|
* График истории цен товара или услуги.
|
7
|
-
* TODO: TASK[#7482] Перепроверить возможность использования TuiLineDaysChart.
|
8
9
|
*/
|
9
10
|
export declare class ScPriceHistoryComponent implements OnInit {
|
10
|
-
private readonly
|
11
|
+
private readonly catalogService;
|
12
|
+
private readonly months$;
|
13
|
+
private readonly context?;
|
11
14
|
/**
|
12
|
-
*
|
15
|
+
* {@link Observable} временного промежутка истории цен.
|
13
16
|
*/
|
14
|
-
|
17
|
+
range$: Observable<TuiDayRange>;
|
15
18
|
/**
|
16
|
-
*
|
17
|
-
*/
|
18
|
-
maxPrice?: number;
|
19
|
-
/**
|
20
|
-
* Минимальная цена товара.
|
19
|
+
* Товар или услуга, для которого необходимо отобразить историю цен.
|
21
20
|
*/
|
22
|
-
|
21
|
+
product: ScProduct;
|
23
22
|
/**
|
24
|
-
*
|
23
|
+
* {@link Observable} истории цен.
|
25
24
|
*/
|
26
|
-
|
27
|
-
devicePixelRatio?: number;
|
28
|
-
renderer?: string;
|
29
|
-
width?: number | string;
|
30
|
-
height?: number | string;
|
31
|
-
locale?: string;
|
32
|
-
};
|
25
|
+
history$?: Observable<ReadonlyArray<[TuiDay, number]>>;
|
33
26
|
/**
|
34
|
-
*
|
27
|
+
* Максимальная цена товара.
|
35
28
|
*/
|
36
|
-
|
29
|
+
priceInfo$?: Observable<{
|
30
|
+
min: number;
|
31
|
+
max: number;
|
32
|
+
}>;
|
37
33
|
/**
|
38
|
-
*
|
34
|
+
* {@link Observable} функция для преобразования значения number в строку в подсказке по оси X.
|
39
35
|
*/
|
40
|
-
|
36
|
+
readonly xStringify$: Observable<TuiStringHandler<TuiDay>>;
|
41
37
|
/**
|
42
|
-
*
|
38
|
+
* Функция для преобразования значения number в строку в подсказке по оси Y.
|
39
|
+
*
|
40
|
+
* @param value Значение оси Y.
|
43
41
|
*/
|
44
|
-
|
42
|
+
readonly yStringify: TuiStringHandler<number>;
|
45
43
|
/**
|
46
44
|
* Инициализирует экземпляр класса {@link ScPriceHistoryComponent}.
|
47
45
|
*
|
48
|
-
* @param
|
46
|
+
* @param catalogService Сервис для работы с каталогом.
|
47
|
+
* @param months$ Перечисление месяцев.
|
48
|
+
* @param context Контекст диалогового окна, в котором открыт компонент.
|
49
49
|
*/
|
50
|
-
constructor(
|
50
|
+
constructor(catalogService: ScCatalogService, months$: Observable<readonly string[]>, context?: TuiDialogContext<void, {
|
51
|
+
product: ScProduct;
|
52
|
+
}> | undefined);
|
51
53
|
/** @inheritDoc */
|
52
54
|
ngOnInit(): void;
|
53
55
|
/**
|
54
|
-
*
|
56
|
+
* Вычисляет подписи даты к оси X.
|
55
57
|
*
|
56
|
-
* @param
|
57
|
-
|
58
|
-
|
59
|
-
/**
|
60
|
-
* Устанавливает новые данные {@link ScPriceHistoryComponent.eChartsInstance}.
|
58
|
+
* @param param0 {@link TuiDayRange} Временной промежуток истории цен.
|
59
|
+
* @param param0.from {@link TuiDay} Дата начала истории цен.
|
60
|
+
* @param param0.to {@link TuiDay} Дата конца истории цен.
|
61
61
|
*/
|
62
|
-
|
62
|
+
computeLabels$({ from, to }: TuiDayRange): Observable<readonly string[]>;
|
63
63
|
/**
|
64
|
-
*
|
64
|
+
* Вычисляет данные для отображения на графике.
|
65
65
|
*
|
66
|
-
* @param
|
67
|
-
* @param
|
68
|
-
* @param
|
66
|
+
* @param param0 {@link TuiDayRange} Временной промежуток истории цен.
|
67
|
+
* @param param0.from {@link TuiDay} Дата начала истории цен.
|
68
|
+
* @param param0.to {@link TuiDay} Дата конца истории цен.
|
69
|
+
* @param history История цен.
|
69
70
|
*/
|
70
|
-
|
71
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<ScPriceHistoryComponent,
|
72
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<ScPriceHistoryComponent, "sc-price-history", never, { "
|
71
|
+
computeValue({ from, to }: TuiDayRange, history: ReadonlyArray<[TuiDay, number]>): ReadonlyArray<[TuiDay, number]>;
|
72
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ScPriceHistoryComponent, [null, null, { optional: true; }]>;
|
73
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<ScPriceHistoryComponent, "sc-price-history", never, { "product": "product"; }, {}, never, never, false>;
|
73
74
|
}
|
@@ -12,13 +12,13 @@ import * as i10 from "@angular/router";
|
|
12
12
|
import * as i11 from "@taiga-ui/core";
|
13
13
|
import * as i12 from "@taiga-ui/kit";
|
14
14
|
import * as i13 from "@angular/forms";
|
15
|
-
import * as i14 from "
|
16
|
-
import * as i15 from "@taiga-ui/
|
15
|
+
import * as i14 from "@taiga-ui/cdk";
|
16
|
+
import * as i15 from "@taiga-ui/addon-charts";
|
17
17
|
/**
|
18
18
|
* Модуль каталога.
|
19
19
|
*/
|
20
20
|
export declare class ScCatalogModule {
|
21
21
|
static ɵfac: i0.ɵɵFactoryDeclaration<ScCatalogModule, never>;
|
22
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<ScCatalogModule, [typeof i1.ScPriceListPaginationComponent, typeof i2.ScCategoryCardComponent, typeof i3.ScFavoriteBtnComponent, typeof i4.ScInputQuantityComponent, typeof i5.ScPriceCardComponent, typeof i6.ScPriceWarehouseStockComponent, typeof i7.ScPriceHistoryComponent, typeof i8.ScCategoriesListComponent], [typeof i9.CommonModule, typeof i10.RouterModule, typeof i11.TuiButtonModule, typeof i11.TuiSvgModule, typeof i12.TuiIslandModule, typeof i12.TuiInputNumberModule, typeof i11.TuiLabelModule, typeof i11.TuiTextfieldControllerModule, typeof i13.FormsModule, typeof i13.ReactiveFormsModule, typeof i11.TuiHintModule, typeof i11.TuiModeModule, typeof i12.TuiFieldErrorPipeModule, typeof i11.TuiLoaderModule, typeof i11.TuiLinkModule, typeof i12.TuiElasticContainerModule, typeof i14.
|
22
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<ScCatalogModule, [typeof i1.ScPriceListPaginationComponent, typeof i2.ScCategoryCardComponent, typeof i3.ScFavoriteBtnComponent, typeof i4.ScInputQuantityComponent, typeof i5.ScPriceCardComponent, typeof i6.ScPriceWarehouseStockComponent, typeof i7.ScPriceHistoryComponent, typeof i8.ScCategoriesListComponent], [typeof i9.CommonModule, typeof i10.RouterModule, typeof i11.TuiButtonModule, typeof i11.TuiSvgModule, typeof i12.TuiIslandModule, typeof i12.TuiInputNumberModule, typeof i11.TuiLabelModule, typeof i11.TuiTextfieldControllerModule, typeof i13.FormsModule, typeof i13.ReactiveFormsModule, typeof i11.TuiHintModule, typeof i11.TuiModeModule, typeof i12.TuiFieldErrorPipeModule, typeof i11.TuiLoaderModule, typeof i11.TuiLinkModule, typeof i12.TuiElasticContainerModule, typeof i14.TuiLetModule, typeof i14.TuiRepeatTimesModule, typeof i12.TuiHighlightModule, typeof i15.TuiLineDaysChartModule, typeof i15.TuiAxesModule], [typeof i1.ScPriceListPaginationComponent, typeof i2.ScCategoryCardComponent, typeof i3.ScFavoriteBtnComponent, typeof i4.ScInputQuantityComponent, typeof i5.ScPriceCardComponent, typeof i6.ScPriceWarehouseStockComponent, typeof i7.ScPriceHistoryComponent, typeof i8.ScCategoriesListComponent]>;
|
23
23
|
static ɵinj: i0.ɵɵInjectorDeclaration<ScCatalogModule>;
|
24
24
|
}
|
package/esm2020/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.mjs
CHANGED
@@ -1,6 +1,5 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Output } from '@angular/core';
|
2
2
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
3
|
-
import { ScUserMetrikaGoalsEnum } from '@snabcentr/client-core';
|
4
3
|
import { tuiIsFalsy } from '@taiga-ui/cdk';
|
5
4
|
import { catchError, filter, map, of, share, startWith, Subject, switchMap } from 'rxjs';
|
6
5
|
import * as i0 from "@angular/core";
|
@@ -17,11 +16,9 @@ export class ScSignInFormByEmailComponent {
|
|
17
16
|
* Инициализирует экземпляр класса {@link ScSignInFormByEmailComponent}.
|
18
17
|
*
|
19
18
|
* @param authService Сервис аутентификации.
|
20
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
21
19
|
*/
|
22
|
-
constructor(authService
|
20
|
+
constructor(authService) {
|
23
21
|
this.authService = authService;
|
24
|
-
this.userMetrikaService = userMetrikaService;
|
25
22
|
/**
|
26
23
|
* Группа полей ввода для формы «Вход на сайт».
|
27
24
|
*/
|
@@ -55,22 +52,13 @@ export class ScSignInFormByEmailComponent {
|
|
55
52
|
*/
|
56
53
|
this.forgotPassword = new EventEmitter();
|
57
54
|
}
|
58
|
-
/** @inheritDoc */
|
59
|
-
ngOnInit() {
|
60
|
-
this.userMetrikaService.emitUserMetrikaEvent({
|
61
|
-
target: ScUserMetrikaGoalsEnum.signInShow,
|
62
|
-
params: {
|
63
|
-
type: 'email',
|
64
|
-
},
|
65
|
-
});
|
66
|
-
}
|
67
55
|
}
|
68
|
-
ScSignInFormByEmailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByEmailComponent, deps: [{ token: i1.ScAuthService }
|
56
|
+
ScSignInFormByEmailComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByEmailComponent, deps: [{ token: i1.ScAuthService }], target: i0.ɵɵFactoryTarget.Component });
|
69
57
|
ScSignInFormByEmailComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScSignInFormByEmailComponent, selector: "sc-sign-in-form-by-email", outputs: { forgotPassword: "forgotPassword" }, ngImport: i0, template: "<form [formGroup]=\"formByEmail\" (ngSubmit)=\"onSubmit.next()\">\n <div class=\"flex flex-col gap-4 mb-8\">\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=\"login\">\n \u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\n <input tuiTextfield autocomplete=\"email\" />\n </tui-input>\n <tui-error formControlName=\"login\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n </label>\n <label tuiLabel=\"\u041F\u0430\u0440\u043E\u043B\u044C\">\n <tui-input-password formControlName=\"password\">\n \u041F\u0430\u0440\u043E\u043B\u044C\n <input tuiTextfield autocomplete=\"current-password\" />\n </tui-input-password>\n <tui-error formControlName=\"password\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n </label>\n <tui-error [error]=\"[] | tuiFieldError | async\"></tui-error>\n </div>\n <div class=\"flex flex-col gap-4 items-center mb-4\">\n <a tuiLink [pseudo]=\"true\" (click)=\"forgotPassword.emit()\" class=\"text-base\">\u0417\u0430\u0431\u044B\u043B\u0438 \u043F\u0430\u0440\u043E\u043B\u044C?</a>\n <button tuiButton type=\"submit\" [showLoader]=\"!!(loadingEmailAuth$ | async)\" [disabled]=\"formByEmail.invalid || !!(loadingEmailAuth$ | async)\" icon=\"scIconLogIn\">\n \u0412\u043E\u0439\u0442\u0438\n </button>\n </div>\n</form>\n", dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { 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: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.TuiInputPasswordComponent, selector: "tui-input-password" }, { kind: "directive", type: i3.TuiInputPasswordDirective, selector: "tui-input-password" }, { kind: "component", type: i4.TuiTextfieldComponent, selector: "input[tuiTextfield], textarea[tuiTextfield]" }, { kind: "component", type: i3.TuiInputComponent, selector: "tui-input" }, { kind: "directive", type: i3.TuiInputDirective, selector: "tui-input" }, { kind: "component", type: i4.TuiLinkComponent, selector: "a[tuiLink], button[tuiLink]", inputs: ["pseudo", "icon", "iconAlign", "iconRotated", "mode"], exportAs: ["tuiLink"] }, { 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: i4.TuiLabelComponent, selector: "label[tuiLabel]", inputs: ["tuiLabel", "context"] }, { kind: "component", type: i4.TuiErrorComponent, selector: "tui-error", inputs: ["error"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i3.TuiFieldErrorPipe, name: "tuiFieldError" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
70
58
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByEmailComponent, decorators: [{
|
71
59
|
type: Component,
|
72
60
|
args: [{ selector: 'sc-sign-in-form-by-email', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"formByEmail\" (ngSubmit)=\"onSubmit.next()\">\n <div class=\"flex flex-col gap-4 mb-8\">\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=\"login\">\n \u0410\u0434\u0440\u0435\u0441 \u044D\u043B\u0435\u043A\u0442\u0440\u043E\u043D\u043D\u043E\u0439 \u043F\u043E\u0447\u0442\u044B\n <input tuiTextfield autocomplete=\"email\" />\n </tui-input>\n <tui-error formControlName=\"login\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n </label>\n <label tuiLabel=\"\u041F\u0430\u0440\u043E\u043B\u044C\">\n <tui-input-password formControlName=\"password\">\n \u041F\u0430\u0440\u043E\u043B\u044C\n <input tuiTextfield autocomplete=\"current-password\" />\n </tui-input-password>\n <tui-error formControlName=\"password\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n </label>\n <tui-error [error]=\"[] | tuiFieldError | async\"></tui-error>\n </div>\n <div class=\"flex flex-col gap-4 items-center mb-4\">\n <a tuiLink [pseudo]=\"true\" (click)=\"forgotPassword.emit()\" class=\"text-base\">\u0417\u0430\u0431\u044B\u043B\u0438 \u043F\u0430\u0440\u043E\u043B\u044C?</a>\n <button tuiButton type=\"submit\" [showLoader]=\"!!(loadingEmailAuth$ | async)\" [disabled]=\"formByEmail.invalid || !!(loadingEmailAuth$ | async)\" icon=\"scIconLogIn\">\n \u0412\u043E\u0439\u0442\u0438\n </button>\n </div>\n</form>\n" }]
|
73
|
-
}], ctorParameters: function () { return [{ type: i1.ScAuthService }
|
61
|
+
}], ctorParameters: function () { return [{ type: i1.ScAuthService }]; }, propDecorators: { forgotPassword: [{
|
74
62
|
type: Output
|
75
63
|
}] } });
|
76
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-sign-in-form-by-email.component.js","sourceRoot":"","sources":["../../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.ts","../../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.html"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAqC,sBAAsB,EAAwB,MAAM,wBAAwB,CAAC;AACzH,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;AAIrG;;GAEG;AAMH,MAAM,OAAO,4BAA4B;IAoDrC;;;;;OAKG;IACH,YACqB,WAA0B,EAC1B,kBAAwC;QADxC,gBAAW,GAAX,WAAW,CAAe;QAC1B,uBAAkB,GAAlB,kBAAkB,CAAsB;QA3D7D;;WAEG;QACa,gBAAW,GAAc,IAAI,SAAS,CAAC;YACnD,KAAK,EAAE,IAAI,WAAW,CAAgB,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACpF,QAAQ,EAAE,IAAI,WAAW,CAAgB,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;SACtE,CAAC,CAAC;QAEH;;WAEG;QACa,aAAQ,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAE9D;;WAEG;QACc,kBAAa,GAAkC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAC9E,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EACpC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAe,CAAC,EAC3C,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAChB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,CACnC,UAAU,CAAC,CAAC,KAAwB,EAAE,EAAE;YACpC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAyB,CAAC;YAEtD,KAAK,MAAM,GAAG,IAAI,aAAa,CAAC,MAAM,EAAE;gBACpC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,SAAS,CAAC,EAAE,cAAc,EAAE,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aACvF;YAED,IAAI,CAAC,aAAa,CAAC,MAAM,IAAI,aAAa,CAAC,OAAO,EAAE;gBAChD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aAC3E;YAED,OAAO,EAAE,CAAC,EAAgB,CAAC,CAAC;QAChC,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,CAClB,CACJ,EACD,KAAK,EAAE,CACV,CAAC;QAEF;;WAEG;QACa,sBAAiB,GAAwB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;QAElG;;WAEG;QAEa,mBAAc,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAW3E,CAAC;IAEJ,kBAAkB;IACX,QAAQ;QACX,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC;YACzC,MAAM,EAAE,sBAAsB,CAAC,UAAU;YACzC,MAAM,EAAE;gBACJ,IAAI,EAAE,OAAO;aAChB;SACJ,CAAC,CAAC;IACP,CAAC;;yHAvEQ,4BAA4B;6GAA5B,4BAA4B,+GCnBzC,0oDAyBA;2FDNa,4BAA4B;kBALxC,SAAS;+BACI,0BAA0B,mBAEnB,uBAAuB,CAAC,MAAM;uIAoD/B,cAAc;sBAD7B,MAAM","sourcesContent":["/* eslint-disable @typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, OnInit, Output } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { IAuthToken, ILogin, ScAuthService, ScUserMetrikaGoalsEnum, ScUserMetrikaService } from '@snabcentr/client-core';\nimport { tuiIsFalsy } from '@taiga-ui/cdk';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../interfaces/ApiErrorResponse';\n\n/**\n * Компонент аутентификации по адресу электронной почты и паролю.\n */\n@Component({\n    selector: 'sc-sign-in-form-by-email',\n    templateUrl: './sc-sign-in-form-by-email.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSignInFormByEmailComponent implements OnInit {\n    /**\n     * Группа полей ввода для формы «Вход на сайт».\n     */\n    public readonly formByEmail: FormGroup = new FormGroup({\n        login: new FormControl<string | null>(null, [Validators.required, Validators.email]),\n        password: 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 emailRequest$: Observable<IAuthToken | null> = this.onSubmit.pipe(\n        filter(() => this.formByEmail.valid),\n        map(() => this.formByEmail.value as ILogin),\n        switchMap((value) =>\n            this.authService.getSignIn$(value).pipe(\n                catchError((error: HttpErrorResponse) => {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    for (const key in errorResponse.errors) {\n                        this.formByEmail.get(key)?.setErrors({ serverResponse: errorResponse.errors[key] });\n                    }\n\n                    if (!errorResponse.errors && errorResponse.message) {\n                        this.formByEmail.setErrors({ serverResponse: [errorResponse.message] });\n                    }\n\n                    return of({} as IAuthToken);\n                }),\n                startWith(null)\n            )\n        ),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по email.\n     */\n    public readonly loadingEmailAuth$: Observable<boolean> = this.emailRequest$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Сигнал нажатия на кнопку \"Забыли пароль\".\n     */\n    @Output()\n    public readonly forgotPassword: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSignInFormByEmailComponent}.\n     *\n     * @param authService Сервис аутентификации.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     */\n    public constructor(\n        private readonly authService: ScAuthService,\n        private readonly userMetrikaService: ScUserMetrikaService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.signInShow,\n            params: {\n                type: 'email',\n            },\n        });\n    }\n}\n","<form [formGroup]=\"formByEmail\" (ngSubmit)=\"onSubmit.next()\">\n    <div class=\"flex flex-col gap-4 mb-8\">\n        <label tuiLabel=\"Адрес электронной почты\">\n            <tui-input formControlName=\"login\">\n                Адрес электронной почты\n                <input tuiTextfield autocomplete=\"email\" />\n            </tui-input>\n            <tui-error formControlName=\"login\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n        </label>\n        <label tuiLabel=\"Пароль\">\n            <tui-input-password formControlName=\"password\">\n                Пароль\n                <input tuiTextfield autocomplete=\"current-password\" />\n            </tui-input-password>\n            <tui-error formControlName=\"password\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n        </label>\n        <tui-error [error]=\"[] | tuiFieldError | async\"></tui-error>\n    </div>\n    <div class=\"flex flex-col gap-4 items-center mb-4\">\n        <a tuiLink [pseudo]=\"true\" (click)=\"forgotPassword.emit()\" class=\"text-base\">Забыли пароль?</a>\n        <button tuiButton type=\"submit\" [showLoader]=\"!!(loadingEmailAuth$ | async)\" [disabled]=\"formByEmail.invalid || !!(loadingEmailAuth$ | async)\" icon=\"scIconLogIn\">\n            Войти\n        </button>\n    </div>\n</form>\n"]}
|
64
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-sign-in-form-by-email.component.js","sourceRoot":"","sources":["../../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.ts","../../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form-by-email/sc-sign-in-form-by-email.component.html"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAEpE,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,EAAc,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;;;;;;AAIrG;;GAEG;AAMH,MAAM,OAAO,4BAA4B;IAmDrC;;;;OAIG;IACH,YAAoC,WAA0B;QAA1B,gBAAW,GAAX,WAAW,CAAe;QAvD9D;;WAEG;QACa,gBAAW,GAAc,IAAI,SAAS,CAAC;YACnD,KAAK,EAAE,IAAI,WAAW,CAAgB,IAAI,EAAE,CAAC,UAAU,CAAC,QAAQ,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACpF,QAAQ,EAAE,IAAI,WAAW,CAAgB,IAAI,EAAE,UAAU,CAAC,QAAQ,CAAC;SACtE,CAAC,CAAC;QAEH;;WAEG;QACa,aAAQ,GAAkB,IAAI,OAAO,EAAQ,CAAC;QAE9D;;WAEG;QACc,kBAAa,GAAkC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAC9E,MAAM,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EACpC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAe,CAAC,EAC3C,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAChB,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,IAAI,CACnC,UAAU,CAAC,CAAC,KAAwB,EAAE,EAAE;YACpC,MAAM,aAAa,GAAG,KAAK,CAAC,KAAyB,CAAC;YAEtD,KAAK,MAAM,GAAG,IAAI,aAAa,CAAC,MAAM,EAAE;gBACpC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,SAAS,CAAC,EAAE,cAAc,EAAE,aAAa,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;aACvF;YAED,IAAI,CAAC,aAAa,CAAC,MAAM,IAAI,aAAa,CAAC,OAAO,EAAE;gBAChD,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;aAC3E;YAED,OAAO,EAAE,CAAC,EAAgB,CAAC,CAAC;QAChC,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,CAClB,CACJ,EACD,KAAK,EAAE,CACV,CAAC;QAEF;;WAEG;QACa,sBAAiB,GAAwB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC;QAElG;;WAEG;QACuB,mBAAc,GAAuB,IAAI,YAAY,EAAQ,CAAC;IAOvB,CAAC;;yHAxDzD,4BAA4B;6GAA5B,4BAA4B,+GCnBzC,0oDAyBA;2FDNa,4BAA4B;kBALxC,SAAS;+BACI,0BAA0B,mBAEnB,uBAAuB,CAAC,MAAM;oGAmDrB,cAAc;sBAAvC,MAAM","sourcesContent":["/* eslint-disable @typescript-eslint/unbound-method */\n\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { ChangeDetectionStrategy, Component, EventEmitter, Output } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { IAuthToken, ILogin, ScAuthService } from '@snabcentr/client-core';\nimport { tuiIsFalsy } from '@taiga-ui/cdk';\nimport { catchError, filter, map, Observable, of, share, startWith, Subject, switchMap } from 'rxjs';\n\nimport { ApiErrorResponse } from '../../interfaces/ApiErrorResponse';\n\n/**\n * Компонент аутентификации по адресу электронной почты и паролю.\n */\n@Component({\n    selector: 'sc-sign-in-form-by-email',\n    templateUrl: './sc-sign-in-form-by-email.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSignInFormByEmailComponent {\n    /**\n     * Группа полей ввода для формы «Вход на сайт».\n     */\n    public readonly formByEmail: FormGroup = new FormGroup({\n        login: new FormControl<string | null>(null, [Validators.required, Validators.email]),\n        password: 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 emailRequest$: Observable<IAuthToken | null> = this.onSubmit.pipe(\n        filter(() => this.formByEmail.valid),\n        map(() => this.formByEmail.value as ILogin),\n        switchMap((value) =>\n            this.authService.getSignIn$(value).pipe(\n                catchError((error: HttpErrorResponse) => {\n                    const errorResponse = error.error as ApiErrorResponse;\n\n                    for (const key in errorResponse.errors) {\n                        this.formByEmail.get(key)?.setErrors({ serverResponse: errorResponse.errors[key] });\n                    }\n\n                    if (!errorResponse.errors && errorResponse.message) {\n                        this.formByEmail.setErrors({ serverResponse: [errorResponse.message] });\n                    }\n\n                    return of({} as IAuthToken);\n                }),\n                startWith(null)\n            )\n        ),\n        share()\n    );\n\n    /**\n     * {@link Observable} изменения состояния загрузки данных аутентификации по email.\n     */\n    public readonly loadingEmailAuth$: Observable<boolean> = this.emailRequest$.pipe(map(tuiIsFalsy));\n\n    /**\n     * Сигнал нажатия на кнопку \"Забыли пароль\".\n     */\n    @Output() public readonly forgotPassword: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSignInFormByEmailComponent}.\n     *\n     * @param authService Сервис аутентификации.\n     */\n    public constructor(private readonly authService: ScAuthService) {}\n}\n","<form [formGroup]=\"formByEmail\" (ngSubmit)=\"onSubmit.next()\">\n    <div class=\"flex flex-col gap-4 mb-8\">\n        <label tuiLabel=\"Адрес электронной почты\">\n            <tui-input formControlName=\"login\">\n                Адрес электронной почты\n                <input tuiTextfield autocomplete=\"email\" />\n            </tui-input>\n            <tui-error formControlName=\"login\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n        </label>\n        <label tuiLabel=\"Пароль\">\n            <tui-input-password formControlName=\"password\">\n                Пароль\n                <input tuiTextfield autocomplete=\"current-password\" />\n            </tui-input-password>\n            <tui-error formControlName=\"password\" [error]=\"[] | tuiFieldError | async\"></tui-error>\n        </label>\n        <tui-error [error]=\"[] | tuiFieldError | async\"></tui-error>\n    </div>\n    <div class=\"flex flex-col gap-4 items-center mb-4\">\n        <a tuiLink [pseudo]=\"true\" (click)=\"forgotPassword.emit()\" class=\"text-base\">Забыли пароль?</a>\n        <button tuiButton type=\"submit\" [showLoader]=\"!!(loadingEmailAuth$ | async)\" [disabled]=\"formByEmail.invalid || !!(loadingEmailAuth$ | async)\" icon=\"scIconLogIn\">\n            Войти\n        </button>\n    </div>\n</form>\n"]}
|
package/esm2020/auth/sc-sign-in-form/sc-sign-in-form-by-phone/sc-sign-in-form-by-phone.component.mjs
CHANGED
@@ -1,6 +1,5 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component } from '@angular/core';
|
2
2
|
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
3
|
-
import { ScUserMetrikaGoalsEnum } from '@snabcentr/client-core';
|
4
3
|
import { tuiIsFalsy } from '@taiga-ui/cdk';
|
5
4
|
import { catchError, filter, map, of, share, startWith, Subject, switchMap } from 'rxjs';
|
6
5
|
import * as i0 from "@angular/core";
|
@@ -18,11 +17,9 @@ export class ScSignInFormByPhoneComponent {
|
|
18
17
|
* Инициализирует экземпляр класса {@link ScSignInFormByPhoneComponent}.
|
19
18
|
*
|
20
19
|
* @param authService Сервис аутентификации.
|
21
|
-
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
22
20
|
*/
|
23
|
-
constructor(authService
|
21
|
+
constructor(authService) {
|
24
22
|
this.authService = authService;
|
25
|
-
this.userMetrikaService = userMetrikaService;
|
26
23
|
/**
|
27
24
|
* Наличие кода подтверждения у пользователя.
|
28
25
|
*/
|
@@ -56,20 +53,11 @@ export class ScSignInFormByPhoneComponent {
|
|
56
53
|
*/
|
57
54
|
this.loading$ = this.request$.pipe(map(tuiIsFalsy));
|
58
55
|
}
|
59
|
-
/** @inheritDoc */
|
60
|
-
ngOnInit() {
|
61
|
-
this.userMetrikaService.emitUserMetrikaEvent({
|
62
|
-
target: ScUserMetrikaGoalsEnum.signInShow,
|
63
|
-
params: {
|
64
|
-
type: 'phone',
|
65
|
-
},
|
66
|
-
});
|
67
|
-
}
|
68
56
|
}
|
69
|
-
ScSignInFormByPhoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByPhoneComponent, deps: [{ token: i1.ScAuthService }
|
57
|
+
ScSignInFormByPhoneComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByPhoneComponent, deps: [{ token: i1.ScAuthService }], target: i0.ɵɵFactoryTarget.Component });
|
70
58
|
ScSignInFormByPhoneComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScSignInFormByPhoneComponent, selector: "sc-sign-in-form-by-phone", ngImport: i0, template: "<form [formGroup]=\"form\" *tuiLet=\"!!(loading$ | async) as loading\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4 items-center mb-4\">\n <sc-verification-phone-check-form [(haveCode)]=\"haveCode\" [shouldBeBusy]=\"true\" [shouldBeConfirmed]=\"true\" class=\"w-full\"></sc-verification-phone-check-form>\n <button *ngIf=\"haveCode\" tuiButton type=\"submit\" [showLoader]=\"loading\" [disabled]=\"form.invalid || loading\" icon=\"scIconLogIn\">\u0412\u043E\u0439\u0442\u0438</button>\n</form>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { 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: "component", type: i4.TuiButtonComponent, selector: "button[tuiButton], button[tuiIconButton], a[tuiButton], a[tuiIconButton]", inputs: ["appearance", "disabled", "icon", "iconRight", "shape", "showLoader", "size"] }, { kind: "directive", type: i5.TuiLetDirective, selector: "[tuiLet]", inputs: ["tuiLet"] }, { kind: "component", type: i6.ScVerificationPhoneCheckFormComponent, selector: "sc-verification-phone-check-form", inputs: ["showCodeFields", "readOnly", "shouldBeBusy", "shouldBeConfirmed", "haveCode"], outputs: ["haveCodeChange"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
71
59
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormByPhoneComponent, decorators: [{
|
72
60
|
type: Component,
|
73
61
|
args: [{ selector: 'sc-sign-in-form-by-phone', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" *tuiLet=\"!!(loading$ | async) as loading\" (ngSubmit)=\"onSubmit.next()\" class=\"flex flex-col gap-4 items-center mb-4\">\n <sc-verification-phone-check-form [(haveCode)]=\"haveCode\" [shouldBeBusy]=\"true\" [shouldBeConfirmed]=\"true\" class=\"w-full\"></sc-verification-phone-check-form>\n <button *ngIf=\"haveCode\" tuiButton type=\"submit\" [showLoader]=\"loading\" [disabled]=\"form.invalid || loading\" icon=\"scIconLogIn\">\u0412\u043E\u0439\u0442\u0438</button>\n</form>\n" }]
|
74
|
-
}], ctorParameters: function () { return [{ type: i1.ScAuthService }
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
62
|
+
}], ctorParameters: function () { return [{ type: i1.ScAuthService }]; } });
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Mtc2lnbi1pbi1mb3JtLWJ5LXBob25lLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC11aS9hdXRoL3NjLXNpZ24taW4tZm9ybS9zYy1zaWduLWluLWZvcm0tYnktcGhvbmUvc2Mtc2lnbi1pbi1mb3JtLWJ5LXBob25lLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NsaWVudC11aS9hdXRoL3NjLXNpZ24taW4tZm9ybS9zYy1zaWduLWluLWZvcm0tYnktcGhvbmUvc2Mtc2lnbi1pbi1mb3JtLWJ5LXBob25lLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUdBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkUsT0FBTyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFcEUsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQWMsRUFBRSxFQUFFLEtBQUssRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7Ozs7QUFJckc7O0dBRUc7QUFNSCxNQUFNLE9BQU8sNEJBQTRCO0lBbURyQzs7OztPQUlHO0lBQ0gsWUFBb0MsV0FBMEI7UUFBMUIsZ0JBQVcsR0FBWCxXQUFXLENBQWU7UUF2RDlEOztXQUVHO1FBQ0ksYUFBUSxHQUFZLEtBQUssQ0FBQztRQUVqQzs7V0FFRztRQUNhLFNBQUksR0FBRyxJQUFJLFNBQVMsQ0FBQztZQUNqQyxLQUFLLEVBQUUsSUFBSSxXQUFXLENBQWdCLElBQUksRUFBRSxDQUFDLFVBQVUsQ0FBQyxRQUFRLEVBQUUsVUFBVSxDQUFDLFNBQVMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1lBQzVGLGdCQUFnQixFQUFFLElBQUksV0FBVyxDQUFnQixJQUFJLEVBQUUsQ0FBQyxVQUFVLENBQUMsUUFBUSxFQUFFLFVBQVUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztTQUN6RyxDQUFDLENBQUM7UUFFSDs7V0FFRztRQUNhLGFBQVEsR0FBa0IsSUFBSSxPQUFPLEVBQVEsQ0FBQztRQUU5RDs7V0FFRztRQUNjLGFBQVEsR0FBa0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQ3pFLEdBQUcsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUMxQixNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQXdCLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxFQUN4RCxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUNoQixJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxJQUFJLENBQ25DLFVBQVUsQ0FBQyxDQUFDLEtBQXdCLEVBQUUsRUFBRTtZQUNwQyxNQUFNLGFBQWEsR0FBRyxLQUFLLENBQUMsS0FBeUIsQ0FBQztZQUV0RCxLQUFLLE1BQU0sR0FBRyxJQUFJLGFBQWEsQ0FBQyxNQUFNLEVBQUU7Z0JBQ3BDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFLFNBQVMsQ0FBQyxFQUFFLGNBQWMsRUFBRSxhQUFhLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQzthQUNoRjtZQUVELElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxJQUFJLGFBQWEsQ0FBQyxPQUFPLEVBQUU7Z0JBQ2hELElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLEVBQUUsY0FBYyxFQUFFLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUMsQ0FBQzthQUNwRTtZQUVELE9BQU8sRUFBRSxDQUFDLEVBQWdCLENBQUMsQ0FBQztRQUNoQyxDQUFDLENBQUMsRUFDRixTQUFTLENBQUMsSUFBSSxDQUFDLENBQ2xCLENBQ0osRUFDRCxLQUFLLEVBQUUsQ0FDVixDQUFDO1FBRUY7O1dBRUc7UUFDYSxhQUFRLEdBQXdCLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBT25CLENBQUM7O3lIQXhEekQsNEJBQTRCOzZHQUE1Qiw0QkFBNEIsZ0VDbkJ6QyxxZ0JBSUE7MkZEZWEsNEJBQTRCO2tCQUx4QyxTQUFTOytCQUNJLDBCQUEwQixtQkFFbkIsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIEB0eXBlc2NyaXB0LWVzbGludC91bmJvdW5kLW1ldGhvZCAqL1xuXG5pbXBvcnQgeyBIdHRwRXJyb3JSZXNwb25zZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sLCBGb3JtR3JvdXAsIFZhbGlkYXRvcnMgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBJQXV0aFRva2VuLCBJUGhvbmVMb2dpbiwgU2NBdXRoU2VydmljZSB9IGZyb20gJ0BzbmFiY2VudHIvY2xpZW50LWNvcmUnO1xuaW1wb3J0IHsgdHVpSXNGYWxzeSB9IGZyb20gJ0B0YWlnYS11aS9jZGsnO1xuaW1wb3J0IHsgY2F0Y2hFcnJvciwgZmlsdGVyLCBtYXAsIE9ic2VydmFibGUsIG9mLCBzaGFyZSwgc3RhcnRXaXRoLCBTdWJqZWN0LCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzJztcblxuaW1wb3J0IHsgQXBpRXJyb3JSZXNwb25zZSB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMvQXBpRXJyb3JSZXNwb25zZSc7XG5cbi8qKlxuICog0JrQvtC80L/QvtC90LXQvdGCINCw0YPRgtC10L3RgtC40YTQuNC60LDRhtC40Lgg0L/QviDQvdC+0LzQtdGA0YMg0YLQtdC70LXRhNC+0L3QsCDQuCDQutC+0LTRgyDQv9C+0LTRgtCy0LXRgNC20LTQtdC90LjRjy5cbiAqL1xuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICdzYy1zaWduLWluLWZvcm0tYnktcGhvbmUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9zYy1zaWduLWluLWZvcm0tYnktcGhvbmUuY29tcG9uZW50Lmh0bWwnLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBTY1NpZ25JbkZvcm1CeVBob25lQ29tcG9uZW50IHtcbiAgICAvKipcbiAgICAgKiDQndCw0LvQuNGH0LjQtSDQutC+0LTQsCDQv9C+0LTRgtCy0LXRgNC20LTQtdC90LjRjyDRgyDQv9C+0LvRjNC30L7QstCw0YLQtdC70Y8uXG4gICAgICovXG4gICAgcHVibGljIGhhdmVDb2RlOiBib29sZWFuID0gZmFsc2U7XG5cbiAgICAvKipcbiAgICAgKiDQk9GA0YPQv9C/0LAg0L/QvtC70LXQuSDQstCy0L7QtNCwINC00LvRjyDRhNC+0YDQvNGLIMKr0JLRhdC+0LQg0L3QsCDRgdCw0LnRgsK7LlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBmb3JtID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICAgIHBob25lOiBuZXcgRm9ybUNvbnRyb2w8c3RyaW5nIHwgbnVsbD4obnVsbCwgW1ZhbGlkYXRvcnMucmVxdWlyZWQsIFZhbGlkYXRvcnMubWluTGVuZ3RoKDEyKV0pLFxuICAgICAgICB2ZXJpZmljYXRpb25Db2RlOiBuZXcgRm9ybUNvbnRyb2w8c3RyaW5nIHwgbnVsbD4obnVsbCwgW1ZhbGlkYXRvcnMucmVxdWlyZWQsIFZhbGlkYXRvcnMubWluTGVuZ3RoKDYpXSksXG4gICAgfSk7XG5cbiAgICAvKipcbiAgICAgKiB7QGxpbmsgU3ViamVjdH0g0YHQvtCx0YvRgtC40Y8g0L7RgtC/0YDQsNCy0LrQuCDRhNC+0YDQvNGLLlxuICAgICAqL1xuICAgIHB1YmxpYyByZWFkb25seSBvblN1Ym1pdDogU3ViamVjdDx2b2lkPiA9IG5ldyBTdWJqZWN0PHZvaWQ+KCk7XG5cbiAgICAvKipcbiAgICAgKiB7QGxpbmsgT2JzZXJ2YWJsZX0g0LfQsNC/0YDQvtGB0LAg0LTQsNC90L3Ri9GFINCw0YPRgtC10L3RgtC40YTQuNC60LDRhtC40LguXG4gICAgICovXG4gICAgcHJpdmF0ZSByZWFkb25seSByZXF1ZXN0JDogT2JzZXJ2YWJsZTxJQXV0aFRva2VuIHwgbnVsbD4gPSB0aGlzLm9uU3VibWl0LnBpcGUoXG4gICAgICAgIG1hcCgoKSA9PiB0aGlzLmZvcm0udmFsdWUpLFxuICAgICAgICBmaWx0ZXIoKHZhbHVlKTogdmFsdWUgaXMgSVBob25lTG9naW4gPT4gdGhpcy5mb3JtLnZhbGlkKSxcbiAgICAgICAgc3dpdGNoTWFwKCh2YWx1ZSkgPT5cbiAgICAgICAgICAgIHRoaXMuYXV0aFNlcnZpY2UuZ2V0U2lnbkluJCh2YWx1ZSkucGlwZShcbiAgICAgICAgICAgICAgICBjYXRjaEVycm9yKChlcnJvcjogSHR0cEVycm9yUmVzcG9uc2UpID0+IHtcbiAgICAgICAgICAgICAgICAgICAgY29uc3QgZXJyb3JSZXNwb25zZSA9IGVycm9yLmVycm9yIGFzIEFwaUVycm9yUmVzcG9uc2U7XG5cbiAgICAgICAgICAgICAgICAgICAgZm9yIChjb25zdCBrZXkgaW4gZXJyb3JSZXNwb25zZS5lcnJvcnMpIHtcbiAgICAgICAgICAgICAgICAgICAgICAgIHRoaXMuZm9ybS5nZXQoa2V5KT8uc2V0RXJyb3JzKHsgc2VydmVyUmVzcG9uc2U6IGVycm9yUmVzcG9uc2UuZXJyb3JzW2tleV0gfSk7XG4gICAgICAgICAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgICAgICAgICBpZiAoIWVycm9yUmVzcG9uc2UuZXJyb3JzICYmIGVycm9yUmVzcG9uc2UubWVzc2FnZSkge1xuICAgICAgICAgICAgICAgICAgICAgICAgdGhpcy5mb3JtLnNldEVycm9ycyh7IHNlcnZlclJlc3BvbnNlOiBbZXJyb3JSZXNwb25zZS5tZXNzYWdlXSB9KTtcbiAgICAgICAgICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBvZih7fSBhcyBJQXV0aFRva2VuKTtcbiAgICAgICAgICAgICAgICB9KSxcbiAgICAgICAgICAgICAgICBzdGFydFdpdGgobnVsbClcbiAgICAgICAgICAgIClcbiAgICAgICAgKSxcbiAgICAgICAgc2hhcmUoKVxuICAgICk7XG5cbiAgICAvKipcbiAgICAgKiB7QGxpbmsgT2JzZXJ2YWJsZX0g0LjQt9C80LXQvdC10L3QuNGPINGB0L7RgdGC0L7Rj9C90LjRjyDQt9Cw0LPRgNGD0LfQutC4INC00LDQvdC90YvRhSDQsNGD0YLQtdC90YLQuNGE0LjQutCw0YbQuNC4INC/0L4g0L3QvtC80LXRgNGDINGC0LXQu9C10YTQvtC90LAuXG4gICAgICovXG4gICAgcHVibGljIHJlYWRvbmx5IGxvYWRpbmckOiBPYnNlcnZhYmxlPGJvb2xlYW4+ID0gdGhpcy5yZXF1ZXN0JC5waXBlKG1hcCh0dWlJc0ZhbHN5KSk7XG5cbiAgICAvKipcbiAgICAgKiDQmNC90LjRhtC40LDQu9C40LfQuNGA0YPQtdGCINGN0LrQt9C10LzQv9C70Y/RgCDQutC70LDRgdGB0LAge0BsaW5rIFNjU2lnbkluRm9ybUJ5UGhvbmVDb21wb25lbnR9LlxuICAgICAqXG4gICAgICogQHBhcmFtIGF1dGhTZXJ2aWNlINCh0LXRgNCy0LjRgSDQsNGD0YLQtdC90YLQuNGE0LjQutCw0YbQuNC4LlxuICAgICAqL1xuICAgIHB1YmxpYyBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IGF1dGhTZXJ2aWNlOiBTY0F1dGhTZXJ2aWNlKSB7fVxufVxuIiwiPGZvcm0gW2Zvcm1Hcm91cF09XCJmb3JtXCIgKnR1aUxldD1cIiEhKGxvYWRpbmckIHwgYXN5bmMpIGFzIGxvYWRpbmdcIiAobmdTdWJtaXQpPVwib25TdWJtaXQubmV4dCgpXCIgY2xhc3M9XCJmbGV4IGZsZXgtY29sIGdhcC00IGl0ZW1zLWNlbnRlciBtYi00XCI+XG4gICAgPHNjLXZlcmlmaWNhdGlvbi1waG9uZS1jaGVjay1mb3JtIFsoaGF2ZUNvZGUpXT1cImhhdmVDb2RlXCIgW3Nob3VsZEJlQnVzeV09XCJ0cnVlXCIgW3Nob3VsZEJlQ29uZmlybWVkXT1cInRydWVcIiBjbGFzcz1cInctZnVsbFwiPjwvc2MtdmVyaWZpY2F0aW9uLXBob25lLWNoZWNrLWZvcm0+XG4gICAgPGJ1dHRvbiAqbmdJZj1cImhhdmVDb2RlXCIgdHVpQnV0dG9uIHR5cGU9XCJzdWJtaXRcIiBbc2hvd0xvYWRlcl09XCJsb2FkaW5nXCIgW2Rpc2FibGVkXT1cImZvcm0uaW52YWxpZCB8fCBsb2FkaW5nXCIgaWNvbj1cInNjSWNvbkxvZ0luXCI+0JLQvtC50YLQuDwvYnV0dG9uPlxuPC9mb3JtPlxuIl19
|
@@ -1,4 +1,5 @@
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from '@angular/core';
|
2
|
+
import { ScUserMetrikaGoalsEnum } from '@snabcentr/client-core';
|
2
3
|
import { filter } from 'rxjs';
|
3
4
|
import { AuthMethod } from '../enums/auth-method';
|
4
5
|
import * as i0 from "@angular/core";
|
@@ -15,9 +16,11 @@ export class ScSignInFormComponent {
|
|
15
16
|
* Инициализирует экземпляр класса {@link ScSignInFormComponent}.
|
16
17
|
*
|
17
18
|
* @param authService Сервис аутентификации.
|
19
|
+
* @param userMetrikaService Сервис для сбора метрик о действиях пользователей.
|
18
20
|
*/
|
19
|
-
constructor(authService) {
|
21
|
+
constructor(authService, userMetrikaService) {
|
20
22
|
this.authService = authService;
|
23
|
+
this.userMetrikaService = userMetrikaService;
|
21
24
|
/**
|
22
25
|
* Выбранный способ аутентификации.
|
23
26
|
*/
|
@@ -39,6 +42,15 @@ export class ScSignInFormComponent {
|
|
39
42
|
*/
|
40
43
|
this.successAuth = this.authService.getAuthChange().pipe(filter((state) => state));
|
41
44
|
}
|
45
|
+
/** @inheritDoc */
|
46
|
+
ngOnInit() {
|
47
|
+
this.userMetrikaService.emitUserMetrikaEvent({
|
48
|
+
target: ScUserMetrikaGoalsEnum.signInShow,
|
49
|
+
params: {
|
50
|
+
type: this.authMethod,
|
51
|
+
},
|
52
|
+
});
|
53
|
+
}
|
42
54
|
/**
|
43
55
|
* Осуществляет переключение способов аутентификации.
|
44
56
|
*
|
@@ -46,6 +58,12 @@ export class ScSignInFormComponent {
|
|
46
58
|
*/
|
47
59
|
switchAuth(authMethod) {
|
48
60
|
this.authMethod = authMethod;
|
61
|
+
this.userMetrikaService.emitUserMetrikaEvent({
|
62
|
+
target: ScUserMetrikaGoalsEnum.signInShow,
|
63
|
+
params: {
|
64
|
+
type: authMethod,
|
65
|
+
},
|
66
|
+
});
|
49
67
|
}
|
50
68
|
/**
|
51
69
|
* Обрабатывает нажатие на кнопку "Забыли пароль" и выдает сигнал об этом.
|
@@ -54,12 +72,12 @@ export class ScSignInFormComponent {
|
|
54
72
|
this.forgotPassword.emit();
|
55
73
|
}
|
56
74
|
}
|
57
|
-
ScSignInFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormComponent, deps: [{ token: i1.ScAuthService }], target: i0.ɵɵFactoryTarget.Component });
|
58
|
-
ScSignInFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScSignInFormComponent, selector: "sc-sign-in-form", inputs: { authMethod: "authMethod" }, outputs: { forgotPassword: "forgotPassword", signUp: "signUp", successAuth: "successAuth" }, ngImport: i0, template: "<div class=\"flex justify-center
|
75
|
+
ScSignInFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormComponent, deps: [{ token: i1.ScAuthService }, { token: i1.ScUserMetrikaService }], target: i0.ɵɵFactoryTarget.Component });
|
76
|
+
ScSignInFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: ScSignInFormComponent, selector: "sc-sign-in-form", inputs: { authMethod: "authMethod" }, outputs: { forgotPassword: "forgotPassword", signUp: "signUp", successAuth: "successAuth" }, ngImport: i0, template: "<div class=\"mb-4 flex justify-center\">\n <button\n tuiButton\n [tuiMode]=\"authMethod === 'by_phone' ? null : 'onLight'\"\n [appearance]=\"authMethod === 'by_phone' ? 'primary' : 'secondary'\"\n (click)=\"switchAuth(method.byPhone)\"\n class=\"tui-space_right-3 tui-space_bottom-3 !font-bold\"\n >\n \u041F\u043E \u0442\u0435\u043B\u0435\u0444\u043E\u043D\u0443\n </button>\n\n <button\n tuiButton\n [tuiMode]=\"authMethod === 'by_email' ? null : 'onLight'\"\n [appearance]=\"authMethod === 'by_email' ? 'primary' : 'secondary'\"\n (click)=\"switchAuth(method.byEmail)\"\n class=\"tui-space_left-3 tui-space_bottom-3 !font-bold\"\n >\n \u041F\u043E e-mail\n </button>\n</div>\n\n<sc-sign-in-form-by-email\n *ngIf=\"authMethod === 'by_email'\"\n (forgotPassword)=\"onForgotPassword()\"\n></sc-sign-in-form-by-email>\n\n<sc-sign-in-form-by-phone [class.hidden]=\"authMethod !== 'by_phone'\"></sc-sign-in-form-by-phone>\n\n<div class=\"flex flex-col items-center gap-4\">\n <span class=\"font-medium text-tui-text-02\">\u0415\u0449\u0435 \u043D\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u043D\u044B?</span>\n <button\n tuiButton\n tuiMode=\"onLight\"\n (click)=\"signUp.emit()\"\n type=\"button\"\n icon=\"scIconAddProfile\"\n appearance=\"secondary\"\n >\n \u0417\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u0442\u044C\u0441\u044F\n </button>\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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.ScSignInFormByPhoneComponent, selector: "sc-sign-in-form-by-phone" }, { kind: "component", type: i5.ScSignInFormByEmailComponent, selector: "sc-sign-in-form-by-email", outputs: ["forgotPassword"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
59
77
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: ScSignInFormComponent, decorators: [{
|
60
78
|
type: Component,
|
61
|
-
args: [{ selector: 'sc-sign-in-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex justify-center
|
62
|
-
}], ctorParameters: function () { return [{ type: i1.ScAuthService }]; }, propDecorators: { authMethod: [{
|
79
|
+
args: [{ selector: 'sc-sign-in-form', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"mb-4 flex justify-center\">\n <button\n tuiButton\n [tuiMode]=\"authMethod === 'by_phone' ? null : 'onLight'\"\n [appearance]=\"authMethod === 'by_phone' ? 'primary' : 'secondary'\"\n (click)=\"switchAuth(method.byPhone)\"\n class=\"tui-space_right-3 tui-space_bottom-3 !font-bold\"\n >\n \u041F\u043E \u0442\u0435\u043B\u0435\u0444\u043E\u043D\u0443\n </button>\n\n <button\n tuiButton\n [tuiMode]=\"authMethod === 'by_email' ? null : 'onLight'\"\n [appearance]=\"authMethod === 'by_email' ? 'primary' : 'secondary'\"\n (click)=\"switchAuth(method.byEmail)\"\n class=\"tui-space_left-3 tui-space_bottom-3 !font-bold\"\n >\n \u041F\u043E e-mail\n </button>\n</div>\n\n<sc-sign-in-form-by-email\n *ngIf=\"authMethod === 'by_email'\"\n (forgotPassword)=\"onForgotPassword()\"\n></sc-sign-in-form-by-email>\n\n<sc-sign-in-form-by-phone [class.hidden]=\"authMethod !== 'by_phone'\"></sc-sign-in-form-by-phone>\n\n<div class=\"flex flex-col items-center gap-4\">\n <span class=\"font-medium text-tui-text-02\">\u0415\u0449\u0435 \u043D\u0435 \u0437\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u043D\u044B?</span>\n <button\n tuiButton\n tuiMode=\"onLight\"\n (click)=\"signUp.emit()\"\n type=\"button\"\n icon=\"scIconAddProfile\"\n appearance=\"secondary\"\n >\n \u0417\u0430\u0440\u0435\u0433\u0438\u0441\u0442\u0440\u0438\u0440\u043E\u0432\u0430\u0442\u044C\u0441\u044F\n </button>\n</div>\n" }]
|
80
|
+
}], ctorParameters: function () { return [{ type: i1.ScAuthService }, { type: i1.ScUserMetrikaService }]; }, propDecorators: { authMethod: [{
|
63
81
|
type: Input
|
64
82
|
}], forgotPassword: [{
|
65
83
|
type: Output
|
@@ -68,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
68
86
|
}], successAuth: [{
|
69
87
|
type: Output
|
70
88
|
}] } });
|
71
|
-
//# sourceMappingURL=data:application/json;base64,
|
89
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sc-sign-in-form.component.js","sourceRoot":"","sources":["../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form.component.ts","../../../../../projects/client-ui/auth/sc-sign-in-form/sc-sign-in-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AACxG,OAAO,EAAiB,sBAAsB,EAAwB,MAAM,wBAAwB,CAAC;AACrG,OAAO,EAAE,MAAM,EAAc,MAAM,MAAM,CAAC;AAE1C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;;;;;;;AAElD;;GAEG;AAMH,MAAM,OAAO,qBAAqB;IA0B9B;;;;;OAKG;IACH,YACqB,WAA0B,EAC1B,kBAAwC;QADxC,gBAAW,GAAX,WAAW,CAAe;QAC1B,uBAAkB,GAAlB,kBAAkB,CAAsB;QAjC7D;;WAEG;QACa,eAAU,GAAe,UAAU,CAAC,OAAO,CAAC;QAE5D;;WAEG;QACI,WAAM,GAAsB,UAAU,CAAC;QAE9C;;WAEG;QACuB,mBAAc,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAExF;;WAEG;QACuB,WAAM,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAEhF;;WAEG;QACuB,gBAAW,GAAwB,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAW1H,CAAC;IAEJ,kBAAkB;IACX,QAAQ;QACX,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC;YACzC,MAAM,EAAE,sBAAsB,CAAC,UAAU;YACzC,MAAM,EAAE;gBACJ,IAAI,EAAE,IAAI,CAAC,UAAU;aACxB;SACJ,CAAC,CAAC;IACP,CAAC;IAED;;;;OAIG;IACI,UAAU,CAAC,UAAsB;QACpC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAE7B,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,CAAC;YACzC,MAAM,EAAE,sBAAsB,CAAC,UAAU;YACzC,MAAM,EAAE;gBACJ,IAAI,EAAE,UAAU;aACnB;SACJ,CAAC,CAAC;IACP,CAAC;IAED;;OAEG;IACI,gBAAgB;QACnB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;;kHApEQ,qBAAqB;sGAArB,qBAAqB,0LCdlC,ukDA0CA;2FD5Ba,qBAAqB;kBALjC,SAAS;+BACI,iBAAiB,mBAEV,uBAAuB,CAAC,MAAM;uIAM/B,UAAU;sBAAzB,KAAK;gBAUoB,cAAc;sBAAvC,MAAM;gBAKmB,MAAM;sBAA/B,MAAM;gBAKmB,WAAW;sBAApC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { ScAuthService, ScUserMetrikaGoalsEnum, ScUserMetrikaService } from '@snabcentr/client-core';\nimport { filter, Observable } from 'rxjs';\n\nimport { AuthMethod } from '../enums/auth-method';\n\n/**\n * Компонент аутентификации пользователя.\n */\n@Component({\n    selector: 'sc-sign-in-form',\n    templateUrl: './sc-sign-in-form.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ScSignInFormComponent implements OnInit {\n    /**\n     * Выбранный способ аутентификации.\n     */\n    @Input() public authMethod: AuthMethod = AuthMethod.byEmail;\n\n    /**\n     * Перечисление способов аутентификации.\n     */\n    public method: typeof AuthMethod = AuthMethod;\n\n    /**\n     * Сигнал нажатия на кнопку \"Забыли пароль\".\n     */\n    @Output() public readonly forgotPassword: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Сигнал нажатия на кнопку \"Зарегистрироваться\".\n     */\n    @Output() public readonly signUp: EventEmitter<void> = new EventEmitter<void>();\n\n    /**\n     * Сигнал события аутентификации.\n     */\n    @Output() public readonly successAuth: Observable<boolean> = this.authService.getAuthChange().pipe(filter((state) => state));\n\n    /**\n     * Инициализирует экземпляр класса {@link ScSignInFormComponent}.\n     *\n     * @param authService Сервис аутентификации.\n     * @param userMetrikaService Сервис для сбора метрик о действиях пользователей.\n     */\n    public constructor(\n        private readonly authService: ScAuthService,\n        private readonly userMetrikaService: ScUserMetrikaService\n    ) {}\n\n    /** @inheritDoc */\n    public ngOnInit(): void {\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.signInShow,\n            params: {\n                type: this.authMethod,\n            },\n        });\n    }\n\n    /**\n     * Осуществляет переключение способов аутентификации.\n     *\n     * @param authMethod Выбранный способ аутентификации.\n     */\n    public switchAuth(authMethod: AuthMethod): void {\n        this.authMethod = authMethod;\n\n        this.userMetrikaService.emitUserMetrikaEvent({\n            target: ScUserMetrikaGoalsEnum.signInShow,\n            params: {\n                type: authMethod,\n            },\n        });\n    }\n\n    /**\n     * Обрабатывает нажатие на кнопку \"Забыли пароль\" и выдает сигнал об этом.\n     */\n    public onForgotPassword(): void {\n        this.forgotPassword.emit();\n    }\n}\n","<div class=\"mb-4 flex justify-center\">\n    <button\n        tuiButton\n        [tuiMode]=\"authMethod === 'by_phone' ? null : 'onLight'\"\n        [appearance]=\"authMethod === 'by_phone' ? 'primary' : 'secondary'\"\n        (click)=\"switchAuth(method.byPhone)\"\n        class=\"tui-space_right-3 tui-space_bottom-3 !font-bold\"\n    >\n        По телефону\n    </button>\n\n    <button\n        tuiButton\n        [tuiMode]=\"authMethod === 'by_email' ? null : 'onLight'\"\n        [appearance]=\"authMethod === 'by_email' ? 'primary' : 'secondary'\"\n        (click)=\"switchAuth(method.byEmail)\"\n        class=\"tui-space_left-3 tui-space_bottom-3 !font-bold\"\n    >\n        По e-mail\n    </button>\n</div>\n\n<sc-sign-in-form-by-email\n    *ngIf=\"authMethod === 'by_email'\"\n    (forgotPassword)=\"onForgotPassword()\"\n></sc-sign-in-form-by-email>\n\n<sc-sign-in-form-by-phone [class.hidden]=\"authMethod !== 'by_phone'\"></sc-sign-in-form-by-phone>\n\n<div class=\"flex flex-col items-center gap-4\">\n    <span class=\"font-medium text-tui-text-02\">Еще не зарегистрированы?</span>\n    <button\n        tuiButton\n        tuiMode=\"onLight\"\n        (click)=\"signUp.emit()\"\n        type=\"button\"\n        icon=\"scIconAddProfile\"\n        appearance=\"secondary\"\n    >\n        Зарегистрироваться\n    </button>\n</div>\n"]}
|