trm-tmpl 3.2.1 → 3.3.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/esm2022/lib/app/i18n/i18n-key.enum.mjs +2 -1
- package/esm2022/lib/app/i18n/keys.mjs +3 -2
- package/esm2022/lib/app/models/constants.mjs +4 -2
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.mjs +24 -38
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.mjs +41 -0
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.mjs +99 -117
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.mjs +88 -0
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.mjs +15 -37
- package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.mjs +10 -4
- package/esm2022/lib/app/pages/components/constructor-form/components/index.mjs +3 -1
- package/esm2022/lib/app/pages/components/constructor-form/components/method-amount-hint/method-amount-hint.component.mjs +11 -7
- package/esm2022/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.mjs +20 -24
- package/esm2022/lib/app/pages/components/constructor-form/constructor-form.component.mjs +90 -64
- package/esm2022/lib/app/pages/components/constructor-form/models/field-template.mjs +2 -1
- package/esm2022/lib/app/pages/components/constructor-form/models/index.mjs +1 -2
- package/esm2022/lib/app/pages/components/constructor-form/models/payment-field-options.mjs +1 -1
- package/esm2022/lib/app/pages/components/constructor-form/models/payment-field.mjs +1 -1
- package/esm2022/lib/app/pages/components/constructor-form/services/constructor-form.service.mjs +40 -25
- package/esm2022/lib/app/pages/components/terminal-layout/terminal-layout.component.mjs +11 -9
- package/esm2022/lib/app/pages/directives/fee-template.directive.mjs +17 -0
- package/esm2022/lib/app/pages/directives/index.mjs +2 -1
- package/esm2022/lib/app/services/api-errors.service.mjs +16 -34
- package/esm2022/lib/app/services/csrf.resolver.mjs +6 -18
- package/esm2022/lib/app/services/error.interceptior.mjs +2 -2
- package/esm2022/lib/app/services/local-storage.mjs +70 -0
- package/esm2022/lib/app/services/script-loader.mjs +4 -7
- package/esm2022/lib/app/services/session.data-source.mjs +12 -11
- package/esm2022/lib/app/services/translation/translate-lang-storage.service.mjs +95 -79
- package/esm2022/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.mjs +10 -8
- package/esm2022/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.mjs +6 -6
- package/esm2022/lib/app/shared/components/trm-select/trm-select.component.mjs +1 -1
- package/esm2022/lib/app/terminal-tpl.component.mjs +13 -16
- package/esm2022/lib/app/terminal.module.mjs +43 -75
- package/fesm2022/trm-tmpl.mjs +936 -793
- package/fesm2022/trm-tmpl.mjs.map +1 -1
- package/lib/app/i18n/i18n-key.enum.d.ts +1 -0
- package/lib/app/models/constants.d.ts +3 -1
- package/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.d.ts +7 -10
- package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.d.ts +18 -0
- package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.d.ts +24 -27
- package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.d.ts +16 -0
- package/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.d.ts +6 -10
- package/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.d.ts +3 -3
- package/lib/app/pages/components/constructor-form/components/index.d.ts +2 -0
- package/lib/app/pages/components/constructor-form/components/method-amount-hint/method-amount-hint.component.d.ts +3 -0
- package/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.d.ts +4 -6
- package/lib/app/pages/components/constructor-form/constructor-form.component.d.ts +6 -9
- package/lib/app/pages/components/constructor-form/models/index.d.ts +0 -1
- package/lib/app/pages/components/constructor-form/models/payment-field-options.d.ts +1 -1
- package/lib/app/pages/components/constructor-form/models/payment-field.d.ts +1 -1
- package/lib/app/pages/components/constructor-form/services/constructor-form.service.d.ts +8 -5
- package/lib/app/pages/components/terminal-layout/terminal-layout.component.d.ts +1 -0
- package/lib/app/pages/directives/fee-template.directive.d.ts +7 -0
- package/lib/app/pages/directives/index.d.ts +1 -0
- package/lib/app/services/api-errors.service.d.ts +4 -10
- package/lib/app/services/csrf.resolver.d.ts +1 -4
- package/lib/app/services/local-storage.d.ts +24 -0
- package/lib/app/services/script-loader.d.ts +1 -2
- package/lib/app/services/session.data-source.d.ts +1 -1
- package/lib/app/services/translation/translate-lang-storage.service.d.ts +22 -23
- package/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.d.ts +4 -34
- package/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.d.ts +1 -2
- package/lib/app/shared/components/trm-select/trm-select.component.d.ts +1 -2
- package/lib/app/terminal-tpl.component.d.ts +2 -1
- package/lib/app/terminal.module.d.ts +26 -4
- package/package.json +1 -1
- package/esm2022/lib/app/pages/components/constructor-form/models/constants.mjs +0 -4
- package/lib/app/pages/components/constructor-form/models/constants.d.ts +0 -3
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output, ViewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output, ViewChild, ViewChildren } from '@angular/core';
|
|
2
2
|
import { PaymentFieldTypeEnum, TerminalStep } from './models';
|
|
3
3
|
import { ConstructorFormService } from './services/constructor-form.service';
|
|
4
4
|
import { insertRemoveTrigger } from './../../../helpers/insertRemoveTrigger';
|
|
5
5
|
import { distinctUntilChanged, Subject } from 'rxjs';
|
|
6
|
-
import { takeUntil } from 'rxjs/operators';
|
|
6
|
+
import { first, takeUntil } from 'rxjs/operators';
|
|
7
7
|
import { TranslateService } from '@ngx-translate/core';
|
|
8
8
|
import { CountriesSortPipe } from '../../../pipes/countries-sort.pipe';
|
|
9
9
|
import { NgScrollbar } from 'ngx-scrollbar';
|
|
@@ -24,9 +24,33 @@ import { ConstructorPreparationComponent } from './components/constructor-prepar
|
|
|
24
24
|
import { TabIndexFocusDirective } from '../../directives/tab-index-focus.directive';
|
|
25
25
|
import { TranslateByKeyPipe } from '../../../shared/pipes/translate-by-key.pipe';
|
|
26
26
|
import { GmSkeletonComponent } from '@gmmoney/gm-ui-kit';
|
|
27
|
+
import { OTHER_COUNTRY_CODE } from "../../../helpers";
|
|
28
|
+
import { CardSdkService } from "./components/constructor-field-iframe/card-sdk.service";
|
|
27
29
|
import * as i0 from "@angular/core";
|
|
28
30
|
import * as i1 from "@angular/forms";
|
|
29
31
|
export class ConstructorFormComponent {
|
|
32
|
+
constructor() {
|
|
33
|
+
this.cd = inject(ChangeDetectorRef);
|
|
34
|
+
this.form = inject(ConstructorFormService);
|
|
35
|
+
this.translateSrv = inject(TranslateService);
|
|
36
|
+
this.countriesSortPipe = inject(CountriesSortPipe);
|
|
37
|
+
this.countryTranslatePipe = inject(CountryTranslatePipe);
|
|
38
|
+
this.ngScrollBar = inject(NgScrollbar);
|
|
39
|
+
this.versionSrv = inject(TERMINAL_VERSION_SERVICE_TOKEN);
|
|
40
|
+
this.unSubscriber = new Subject();
|
|
41
|
+
this.preparationStepFilled = false;
|
|
42
|
+
this.TERMINAL_STEP = TerminalStep;
|
|
43
|
+
this.CONSTRUCTOR_FIELD_TYPES = PaymentFieldTypeEnum;
|
|
44
|
+
this.loading = null;
|
|
45
|
+
this.types = [];
|
|
46
|
+
this.canReturnToProject = true;
|
|
47
|
+
this.amountChanged = new EventEmitter();
|
|
48
|
+
this.back = new EventEmitter();
|
|
49
|
+
this.prepare = new EventEmitter();
|
|
50
|
+
this.confirm = new EventEmitter();
|
|
51
|
+
this.onPaymentChanged = new EventEmitter();
|
|
52
|
+
this.I18N_KEY = I18N_KEY;
|
|
53
|
+
}
|
|
30
54
|
get countriesList() {
|
|
31
55
|
return this.countriesSortPipe
|
|
32
56
|
.transform(this.types
|
|
@@ -89,30 +113,6 @@ export class ConstructorFormComponent {
|
|
|
89
113
|
this.form.userCurrency.disable();
|
|
90
114
|
}
|
|
91
115
|
}
|
|
92
|
-
hasFeeHint(options) {
|
|
93
|
-
return options.fee || options.fixedFee || options.min || options.max;
|
|
94
|
-
}
|
|
95
|
-
constructor() {
|
|
96
|
-
this.cd = inject(ChangeDetectorRef);
|
|
97
|
-
this.form = inject(ConstructorFormService);
|
|
98
|
-
this.translateSrv = inject(TranslateService);
|
|
99
|
-
this.countriesSortPipe = inject(CountriesSortPipe);
|
|
100
|
-
this.countryTranslatePipe = inject(CountryTranslatePipe);
|
|
101
|
-
this.ngScrollBar = inject(NgScrollbar);
|
|
102
|
-
this.versionSrv = inject(TERMINAL_VERSION_SERVICE_TOKEN);
|
|
103
|
-
this.unSubscriber = new Subject();
|
|
104
|
-
this.TERMINAL_STEP = TerminalStep;
|
|
105
|
-
this.CONSTRUCTOR_FIELD_TYPES = PaymentFieldTypeEnum;
|
|
106
|
-
this.loading = false;
|
|
107
|
-
this.types = [];
|
|
108
|
-
this.canReturnToProject = true;
|
|
109
|
-
this.amountChanged = new EventEmitter();
|
|
110
|
-
this.back = new EventEmitter();
|
|
111
|
-
this.prepare = new EventEmitter();
|
|
112
|
-
this.confirm = new EventEmitter();
|
|
113
|
-
this.onPaymentChanged = new EventEmitter();
|
|
114
|
-
this.I18N_KEY = I18N_KEY;
|
|
115
|
-
}
|
|
116
116
|
get hasCurrencyMethodSelector() {
|
|
117
117
|
return this.versionSrv.hasCurrencyMethodSelector === true;
|
|
118
118
|
}
|
|
@@ -127,7 +127,19 @@ export class ConstructorFormComponent {
|
|
|
127
127
|
// Get configuration fields
|
|
128
128
|
const countries = this.countriesList;
|
|
129
129
|
const defaultCountry = this.form.defaultCountry;
|
|
130
|
-
|
|
130
|
+
let country = null;
|
|
131
|
+
if (!countries.includes(defaultCountry)) {
|
|
132
|
+
if (countries.includes(OTHER_COUNTRY_CODE)) {
|
|
133
|
+
country = OTHER_COUNTRY_CODE;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
else {
|
|
137
|
+
country = defaultCountry;
|
|
138
|
+
}
|
|
139
|
+
this.form.country.setValue(country);
|
|
140
|
+
if (!country) {
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
131
143
|
if (countries.length === 1 && this.form.country.value) {
|
|
132
144
|
this.form.country.disable();
|
|
133
145
|
}
|
|
@@ -148,10 +160,16 @@ export class ConstructorFormComponent {
|
|
|
148
160
|
.subscribe(() => this.onPaymentChanged.emit(this.form.getRawValue()));
|
|
149
161
|
this.fetchForm();
|
|
150
162
|
}
|
|
163
|
+
if (changes.step?.currentValue && !changes.types && !changes.currency) {
|
|
164
|
+
this.fetchForm();
|
|
165
|
+
}
|
|
151
166
|
if (changes.feeOptions && !changes.feeOptions.firstChange) {
|
|
152
167
|
// need for triggering of the custom validator
|
|
153
168
|
this.form.amount?.updateValueAndValidity();
|
|
154
169
|
}
|
|
170
|
+
if (this.step === TerminalStep.Confirmation) {
|
|
171
|
+
this.preparationStepFilled = true;
|
|
172
|
+
}
|
|
155
173
|
}
|
|
156
174
|
ngAfterViewInit() {
|
|
157
175
|
this.form
|
|
@@ -192,6 +210,10 @@ export class ConstructorFormComponent {
|
|
|
192
210
|
});
|
|
193
211
|
}
|
|
194
212
|
fetchForm() {
|
|
213
|
+
if (!this.form.method.value) {
|
|
214
|
+
this.form.ready = true;
|
|
215
|
+
return;
|
|
216
|
+
}
|
|
195
217
|
this.form.cancelRequests();
|
|
196
218
|
if (this.step !== this.TERMINAL_STEP.Prepare) {
|
|
197
219
|
return;
|
|
@@ -201,14 +223,16 @@ export class ConstructorFormComponent {
|
|
|
201
223
|
this.form
|
|
202
224
|
.init()
|
|
203
225
|
.subscribe(() => {
|
|
204
|
-
if (!this.form.hasWhatToFill()) {
|
|
226
|
+
if (!this.preparationStepFilled && !this.form.hasWhatToFill()) {
|
|
205
227
|
this.send();
|
|
206
228
|
return;
|
|
207
229
|
}
|
|
230
|
+
this.form.payment.updateValueAndValidity({ onlySelf: true });
|
|
208
231
|
this.cd.detectChanges();
|
|
209
232
|
this.scrollToRequisits();
|
|
210
233
|
this.form.maskedWallet = '';
|
|
211
234
|
}, (err) => {
|
|
235
|
+
this.form.payment.updateValueAndValidity({ onlySelf: true });
|
|
212
236
|
this.cd.markForCheck();
|
|
213
237
|
});
|
|
214
238
|
}
|
|
@@ -224,47 +248,49 @@ export class ConstructorFormComponent {
|
|
|
224
248
|
return typeof this.form.config?.description === 'function' ? this.form.config?.description(this.form.getRawValue()) : this.form.config?.description;
|
|
225
249
|
}
|
|
226
250
|
submit() {
|
|
227
|
-
if (
|
|
251
|
+
if (this.feeLoading) {
|
|
228
252
|
return;
|
|
229
253
|
}
|
|
230
|
-
if (this.form.methodName === 'card' && !this.cardIframe?.finished) {
|
|
231
|
-
this.form.continueLoaderOn();
|
|
232
|
-
this.cd.detectChanges();
|
|
233
|
-
this.cardIframe?.submit()
|
|
234
|
-
.then(success => !success && this.form.continueLoaderOff());
|
|
235
|
-
return;
|
|
236
|
-
}
|
|
237
|
-
this.send();
|
|
238
|
-
}
|
|
239
|
-
cardPaid() {
|
|
240
|
-
if (!this.check()) {
|
|
241
|
-
return;
|
|
242
|
-
}
|
|
243
|
-
this.send();
|
|
244
|
-
}
|
|
245
|
-
iframeError(code) {
|
|
246
|
-
this.form.setCDEError(code);
|
|
247
|
-
this.cd.detectChanges();
|
|
248
|
-
}
|
|
249
|
-
check() {
|
|
250
254
|
if (this.step === TerminalStep.Confirmation) {
|
|
251
255
|
this.confirm.emit();
|
|
252
|
-
return
|
|
256
|
+
return;
|
|
253
257
|
}
|
|
254
|
-
if (this.form.config === null) {
|
|
255
|
-
return
|
|
258
|
+
if (this.form.config === null || !this.form.ready) {
|
|
259
|
+
return;
|
|
256
260
|
}
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
261
|
+
this.triggerIframeSubmit();
|
|
262
|
+
if (this.form.invalid || this.error) {
|
|
263
|
+
Object.values(this.form.controls).forEach((control) => {
|
|
264
|
+
control.markAsDirty();
|
|
265
|
+
control.markAsTouched();
|
|
266
|
+
});
|
|
267
|
+
Object.values(this.form.payment.controls).forEach((control) => {
|
|
260
268
|
control.markAsDirty();
|
|
261
269
|
control.markAsTouched();
|
|
262
270
|
control.updateValueAndValidity({ emitEvent: false });
|
|
263
271
|
});
|
|
264
272
|
this.cd.detectChanges();
|
|
265
|
-
return
|
|
273
|
+
return;
|
|
274
|
+
}
|
|
275
|
+
if (this.form.pending) {
|
|
276
|
+
this.form.statusChanges
|
|
277
|
+
.pipe(first(), takeUntil(this.unSubscriber))
|
|
278
|
+
.subscribe((status) => {
|
|
279
|
+
if (status === 'VALID') {
|
|
280
|
+
this.send();
|
|
281
|
+
}
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
else {
|
|
285
|
+
this.send();
|
|
266
286
|
}
|
|
267
|
-
|
|
287
|
+
}
|
|
288
|
+
triggerIframeSubmit() {
|
|
289
|
+
if (!this.form.readyIframesSubmit) {
|
|
290
|
+
return;
|
|
291
|
+
}
|
|
292
|
+
this.sdkList?.forEach((sdk) => sdk.submit());
|
|
293
|
+
this.form.updateValueAndValidityIframes();
|
|
268
294
|
}
|
|
269
295
|
send() {
|
|
270
296
|
const data = this.form.getPaymentValue();
|
|
@@ -295,15 +321,15 @@ export class ConstructorFormComponent {
|
|
|
295
321
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ConstructorFormComponent, isStandalone: true, selector: "app-constructor-form", inputs: { step: "step", error: "error", response: "response", feeLoading: "feeLoading", feeOptions: "feeOptions", currency: "currency", userCurrency: "userCurrency", loading: "loading", types: "types", canReturnToProject: "canReturnToProject", tabIndex: "tabIndex" }, outputs: { amountChanged: "amountChanged", back: "back", prepare: "prepare", confirm: "confirm", onPaymentChanged: "onPaymentChanged" }, providers: [
|
|
296
322
|
ConstructorFormService,
|
|
297
323
|
CountryTranslatePipe, CountriesSortPipe
|
|
298
|
-
], viewQueries: [{ propertyName: "requisites", first: true, predicate: ["paymentRequisites"], descendants: true }, { propertyName: "hintMethod", first: true, predicate: ["hintMethod"], descendants: true }, { propertyName: "cardIframe", first: true, predicate: ["cardIframe"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n @if (form.isCDEFailed) {\r\n <div class=\"constructor__hint cde-error\"\r\n app-ps-select-hint\r\n @insertRemove\r\n >\r\n {{form.getError('cde_error') | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n }\r\n @if (!form.methodInfoLoading) {\r\n @if (form.paymentFormFieldNames.length) {\r\n <div formGroupName=\"payment\"\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n <app-constructor-field-iframe\r\n [hidden]=\"form.isCDEFailed\"\r\n (paid)=\"cardPaid()\"\r\n #cardIframe\r\n (error)=\"iframeError($event)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n }\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\">\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PsSelectComponent, selector: "app-ps-select", inputs: ["methods", "tabIndex"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ConstructorFieldIframeComponent, selector: "app-constructor-field-iframe", inputs: ["tabIndex"], outputs: ["error", "paid", "ready"] }, { kind: "component", type: ConstructorFieldSelectComponent, selector: "app-constructor-field-select", inputs: ["config", "items", "tabIndex"] }, { kind: "component", type: ConstructorFieldTextComponent, selector: "app-constructor-field-text", inputs: ["config", "matDatepicker", "tabIndex"], outputs: ["maskedValueChange"] }, { kind: "component", type: MethodAmountHintComponent, selector: "app-method-amount-hint", inputs: ["loading", "options"] }, { kind: "component", type: ConstructorFieldDateComponent, selector: "app-constructor-field-date", inputs: ["config", "tabIndex"] }, { kind: "component", type: ConstructorPreparationComponent, selector: "app-constructor-preparation", inputs: ["maskedWallet", "wallet", "confirmationText", "methodName", "currency", "amount", "total"] }, { kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
324
|
+
], viewQueries: [{ propertyName: "requisites", first: true, predicate: ["paymentRequisites"], descendants: true }, { propertyName: "hintMethod", first: true, predicate: ["hintMethod"], descendants: true }, { propertyName: "sdkList", predicate: CardSdkService, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [hidden]=\"\r\n form.payment.get(field.name)?.hasError('cde_error')\r\n \"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PsSelectComponent, selector: "app-ps-select", inputs: ["methods", "tabIndex"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ConstructorFieldIframeComponent, selector: "app-constructor-field-iframe", inputs: ["tabIndex"] }, { kind: "component", type: ConstructorFieldSelectComponent, selector: "app-constructor-field-select", inputs: ["config", "items", "tabIndex"] }, { kind: "component", type: ConstructorFieldTextComponent, selector: "app-constructor-field-text", inputs: ["config", "matDatepicker", "tabIndex"], outputs: ["maskedValueChange"] }, { kind: "component", type: MethodAmountHintComponent, selector: "app-method-amount-hint", inputs: ["loading", "options"] }, { kind: "component", type: ConstructorFieldDateComponent, selector: "app-constructor-field-date", inputs: ["config", "tabIndex"] }, { kind: "component", type: ConstructorPreparationComponent, selector: "app-constructor-preparation", inputs: ["maskedWallet", "wallet", "confirmationText", "methodName", "currency", "amount", "total"] }, { kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
299
325
|
}
|
|
300
326
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFormComponent, decorators: [{
|
|
301
327
|
type: Component,
|
|
302
328
|
args: [{ selector: 'app-constructor-form', changeDetection: ChangeDetectionStrategy.OnPush, animations: [insertRemoveTrigger], providers: [
|
|
303
329
|
ConstructorFormService,
|
|
304
330
|
CountryTranslatePipe, CountriesSortPipe
|
|
305
|
-
], standalone: true, imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n @if (form.isCDEFailed) {\r\n <div class=\"constructor__hint cde-error\"\r\n app-ps-select-hint\r\n @insertRemove\r\n >\r\n {{form.getError('cde_error') | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n }\r\n @if (!form.methodInfoLoading) {\r\n @if (form.paymentFormFieldNames.length) {\r\n <div formGroupName=\"payment\"\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n <app-constructor-field-iframe\r\n [hidden]=\"form.isCDEFailed\"\r\n (paid)=\"cardPaid()\"\r\n #cardIframe\r\n (error)=\"iframeError($event)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n }\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\">\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
|
|
306
|
-
}],
|
|
331
|
+
], standalone: true, imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [hidden]=\"\r\n form.payment.get(field.name)?.hasError('cde_error')\r\n \"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
|
|
332
|
+
}], propDecorators: { step: [{
|
|
307
333
|
type: Input
|
|
308
334
|
}], error: [{
|
|
309
335
|
type: Input
|
|
@@ -341,8 +367,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
|
|
|
341
367
|
}], hintMethod: [{
|
|
342
368
|
type: ViewChild,
|
|
343
369
|
args: ['hintMethod', { static: false }]
|
|
344
|
-
}],
|
|
345
|
-
type:
|
|
346
|
-
args: [
|
|
370
|
+
}], sdkList: [{
|
|
371
|
+
type: ViewChildren,
|
|
372
|
+
args: [CardSdkService]
|
|
347
373
|
}] } });
|
|
348
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/constructor-form.component.ts","../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/constructor-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  SimpleChanges,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { PaymentField, PaymentFieldOptions, PaymentFieldTypeEnum, TerminalStep } from './models';\r\nimport { ConstructorFormService } from './services/constructor-form.service';\r\nimport {\r\n  MethodType,\r\n  MethodTypeType,\r\n  TerminalPaymentConfirmResponse,\r\n  TerminalPaymentPrepareRequest,\r\n  TerminalPaymentPrepareResponse\r\n} from '../../../../codegen/model/models';\r\nimport { insertRemoveTrigger } from './../../../helpers/insertRemoveTrigger';\r\nimport { distinctUntilChanged, Subject } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { CountriesSortPipe } from '../../../pipes/countries-sort.pipe';\r\nimport { NgScrollbar } from 'ngx-scrollbar';\r\nimport { I18N_KEY } from './../../../i18n';\r\nimport {\r\n  ConstructorFieldIframeComponent\r\n} from \"./components/constructor-field-iframe/constructor-field-iframe.component\";\r\nimport { CountryTranslatePipe } from '../../../pipes/country-translate.pipe';\r\nimport { TERMINAL_VERSION_SERVICE_TOKEN } from '../../../../const';\r\nimport { VersionServiceInterface } from '../../../models';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\r\nimport { TrmSelectComponent } from '../../../shared/components/trm-select/trm-select.component';\r\nimport {\r\n  TrmSelectLabelTemplateDirective\r\n} from '../../../shared/components/trm-select/trm-select-label-template.directive';\r\nimport { PsSelectComponent } from './components/ps-select/ps-select.component';\r\nimport {\r\n  ConstructorFieldSelectComponent\r\n} from './components/constructor-field-select/constructor-field-select.component';\r\nimport { ConstructorFieldTextComponent } from './components/constructor-field-text/constructor-field-text.component';\r\nimport { MethodAmountHintComponent } from './components/method-amount-hint/method-amount-hint.component';\r\nimport { ConstructorFieldDateComponent } from './components/constructor-field-date/constructor-field-date.component';\r\nimport {\r\n  ConstructorPreparationComponent\r\n} from './components/constructor-preparation/constructor-preparation.component';\r\nimport { TabIndexFocusDirective } from '../../directives/tab-index-focus.directive';\r\nimport { TranslateByKeyPipe } from '../../../shared/pipes/translate-by-key.pipe';\r\nimport { GmSkeletonComponent } from '@gmmoney/gm-ui-kit';\r\n\r\n@Component({\r\n  selector: 'app-constructor-form',\r\n  templateUrl: './constructor-form.component.html',\r\n  styleUrls: ['./constructor-form.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [insertRemoveTrigger],\r\n  providers: [\r\n    ConstructorFormService,\r\n    CountryTranslatePipe, CountriesSortPipe\r\n  ],\r\n  standalone: true,\r\n  imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent]\r\n})\r\nexport class ConstructorFormComponent implements OnChanges, AfterViewInit, OnDestroy {\r\n  private cd = inject(ChangeDetectorRef);\r\n  form = inject(ConstructorFormService);\r\n  private translateSrv = inject(TranslateService);\r\n  private countriesSortPipe = inject(CountriesSortPipe);\r\n  private countryTranslatePipe = inject(CountryTranslatePipe);\r\n  private ngScrollBar = inject(NgScrollbar);\r\n  private versionSrv = inject<VersionServiceInterface>(TERMINAL_VERSION_SERVICE_TOKEN);\r\n\r\n  private unSubscriber = new Subject<void>();\r\n  TERMINAL_STEP = TerminalStep;\r\n  @Input() step: TerminalStep;\r\n  @Input() error?: string;\r\n  @Input() response: TerminalPaymentPrepareResponse & TerminalPaymentConfirmResponse & {\r\n    typeId?: number;\r\n  };\r\n  CONSTRUCTOR_FIELD_TYPES = PaymentFieldTypeEnum;\r\n  @Input() feeLoading: boolean;\r\n  @Input() feeOptions: PaymentFieldOptions;\r\n  @Input() currency: string;\r\n  @Input() userCurrency: string[];\r\n  @Input() loading = false;\r\n  @Input() types: MethodType[] = [];\r\n  @Input() canReturnToProject = true;\r\n  @Output() amountChanged: EventEmitter<number> = new EventEmitter<number>();\r\n  @Output() back: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() prepare: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() confirm: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onPaymentChanged: EventEmitter<any> = new EventEmitter<any>();\r\n  @Input() tabIndex: number;\r\n  countrySearchString: string;\r\n  @ViewChild('paymentRequisites', {static: false}) requisites: ElementRef;\r\n  @ViewChild('hintMethod', {static: false}) hintMethod: ElementRef;\r\n  @ViewChild('cardIframe', {static: false}) cardIframe: ConstructorFieldIframeComponent;\r\n  maskedWallet: string;\r\n\r\n  I18N_KEY = I18N_KEY;\r\n\r\n  get countriesList(): string[] {\r\n    return this.countriesSortPipe\r\n      .transform(\r\n        this.types\r\n          .map(type => type.countryISOCode)\r\n          .filter((value, index, self) => self.indexOf(value) === index)\r\n      )\r\n      .filter((m: string) => {\r\n        if (!this.countrySearchString) {\r\n          return true;\r\n        } else {\r\n          const title: string = this.countryTranslatePipe.transform(m);\r\n          return title.toLowerCase()\r\n            .split(' ').some(\r\n              ts => this.countrySearchString.toLowerCase().split(' ').some(s => ts.includes(s))\r\n            );\r\n        }\r\n      });\r\n  }\r\n\r\n  get methodsList(): MethodTypeType[] {\r\n    return this.types\r\n      .filter(type => type.countryISOCode === this.form.country.value)\r\n      // distinct\r\n      .filter((type, index, self) => self.map(m => m.type.id).indexOf(type.type.id) === index)\r\n      //sorting by the priority\r\n      .sort((m1, m2) => m1.priority > m2.priority ? 1 : ((m1.priority === m2.priority) ? 0 : -1))\r\n      .map(type => type.type);\r\n  }\r\n\r\n  get currenciesList() {\r\n    return this.types\r\n      .filter(type => type.countryISOCode === this.form.country.value && type.type.id === this.form.method.value)\r\n      .map(type => type.currency)\r\n  }\r\n\r\n  get userCurrenciesList() {\r\n    const filteredTypes = this.currenciesList;\r\n\r\n    if (!this.userCurrency) {\r\n      return filteredTypes;\r\n    }\r\n\r\n    return this.userCurrency\r\n      .filter(userCurrency => filteredTypes.includes(userCurrency))\r\n  }\r\n\r\n  private setCurrencyValue() {\r\n    let defaultCurrency = this.form.defaultCurrency;\r\n\r\n    let currencies = this.currenciesList;\r\n    let currency = currencies[0];\r\n    if (defaultCurrency && this.currenciesList.includes(defaultCurrency)) {\r\n      currency = defaultCurrency;\r\n    } else if (this.currency && this.currenciesList.includes(this.currency)) {\r\n      currency = this.currency;\r\n    }\r\n    this.form.currency.setValue(currency);\r\n\r\n    currencies = this.userCurrenciesList;\r\n    currency = currencies[0];\r\n    if (defaultCurrency && this.userCurrenciesList.includes(defaultCurrency)) {\r\n      currency = defaultCurrency;\r\n    } else if (this.currency && this.userCurrenciesList.includes(this.currency)) {\r\n      currency = this.currency;\r\n    }\r\n    this.form.userCurrency.setValue(currency, {emitEvent: false});\r\n    if (currencies.length === 1 && currency && this.form.method.disabled) {\r\n      this.form.userCurrency.disable();\r\n    }\r\n  }\r\n\r\n  hasFeeHint(options: PaymentFieldOptions) {\r\n    return options.fee || options.fixedFee || options.min || options.max;\r\n  }\r\n\r\n  constructor() {\r\n  }\r\n\r\n  get hasCurrencyMethodSelector(): boolean {\r\n    return this.versionSrv.hasCurrencyMethodSelector === true;\r\n  }\r\n\r\n  get lang(): string {\r\n    return this.translateSrv.currentLang;\r\n  }\r\n\r\n  get skeletonLength() {\r\n    return new Array(this.form.fields?.length || 3).fill(0);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.types && this.types?.length || changes.currency && this.currency) {\r\n      // Get configuration fields\r\n      const countries = this.countriesList;\r\n      const defaultCountry = this.form.defaultCountry;\r\n      this.form.country.setValue(countries.includes(defaultCountry) ? defaultCountry : countries[0]);\r\n      if (countries.length === 1 && this.form.country.value) {\r\n        this.form.country.disable();\r\n      }\r\n\r\n      const methods = this.methodsList;\r\n      const defaultMethodName = this.form.defaultMethodName;\r\n      const defaultMethod = methods.find(m => m.name === defaultMethodName)?.id;\r\n      this.form.method.setValue(defaultMethod || methods[0]?.id);\r\n\r\n      this.cd.detectChanges();\r\n      if (methods.length === 1 && this.form.country.disabled) {\r\n        this.form.method.disable();\r\n      }\r\n      this.cd.detectChanges();\r\n      this.setCurrencyValue();\r\n      this.cd.detectChanges();\r\n\r\n      this.form\r\n        .distinctValueChanges()\r\n        .pipe(\r\n          takeUntil(this.unSubscriber)\r\n        )\r\n        .subscribe(() => this.onPaymentChanged.emit(this.form.getRawValue()));\r\n      this.fetchForm();\r\n    }\r\n    if (changes.feeOptions && !changes.feeOptions.firstChange) {\r\n      // need for triggering of the custom validator\r\n      this.form.amount?.updateValueAndValidity();\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.form\r\n      .country\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.cd.detectChanges();\r\n        this.form.saveDefaultCountry();\r\n        this.form.method.setValue(this.methodsList[0].id, {emitEvent: false});\r\n\r\n        const methods = this.methodsList;\r\n        const defaultMethodName = this.form.defaultMethodName;\r\n        const defaultMethod = methods.find(m => m.name === defaultMethodName)?.id;\r\n        this.form.method.setValue(defaultMethod || methods[0].id, {emitEvent: false});\r\n        this.cd.detectChanges();\r\n\r\n        this.setCurrencyValue();\r\n        this.cd.detectChanges();\r\n\r\n        this.fetchForm();\r\n      });\r\n    this.form\r\n      .method\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.form.method.clearValidators();\r\n        this.form.saveDefaultMethodName();\r\n        this.setCurrencyValue();\r\n        this.cd.detectChanges();\r\n        this.fetchForm();\r\n      })\r\n    this.form\r\n      .currency\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.fetchForm();\r\n        this.form.saveDefaultCurrency();\r\n      });\r\n  }\r\n\r\n  private fetchForm() {\r\n    this.form.cancelRequests();\r\n    if (this.step !== this.TERMINAL_STEP.Prepare) {\r\n      return;\r\n    }\r\n    this.form.removePaymentFormControls();\r\n    this.cd.detectChanges();\r\n    this.form\r\n      .init()\r\n      .subscribe(() => {\r\n        if (!this.form.hasWhatToFill()) {\r\n          this.send();\r\n          return;\r\n        }\r\n        this.cd.detectChanges();\r\n        this.scrollToRequisits();\r\n        this.form.maskedWallet = '';\r\n      }, (err) => {\r\n        this.cd.markForCheck();\r\n      });\r\n  }\r\n\r\n  private scrollToRequisits() {\r\n    if (this.requisites || this.hintMethod) {\r\n      this.ngScrollBar?.scrollToElement(this.hintMethod?.nativeElement || this.requisites.nativeElement, {\r\n        duration: 500,\r\n        top: -75\r\n      });\r\n    }\r\n  }\r\n\r\n  get description() {\r\n    return typeof this.form.config?.description === 'function' ? this.form.config?.description(this.form.getRawValue()) : this.form.config?.description;\r\n  }\r\n\r\n  submit() {\r\n    if (!this.check() && !this.loading) {\r\n      return;\r\n    }\r\n    if (this.form.methodName === 'card' && !this.cardIframe?.finished) {\r\n      this.form.continueLoaderOn();\r\n      this.cd.detectChanges();\r\n      this.cardIframe?.submit()\r\n        .then(success => !success && this.form.continueLoaderOff());\r\n      return;\r\n    }\r\n    this.send();\r\n  }\r\n\r\n  cardPaid() {\r\n    if (!this.check()) {\r\n      return;\r\n    }\r\n    this.send();\r\n  }\r\n\r\n  iframeError(code: I18N_KEY) {\r\n    this.form.setCDEError(code);\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  private check() {\r\n    if (this.step === TerminalStep.Confirmation) {\r\n      this.confirm.emit();\r\n      return false;\r\n    }\r\n    if (this.form.config === null) {\r\n      return false;\r\n    }\r\n    if (!this.form.valid || this.error) {\r\n      Object.values(this.form.payment.controls)\r\n        .forEach((control) => {\r\n          control.markAsDirty();\r\n          control.markAsTouched();\r\n          control.updateValueAndValidity({emitEvent: false});\r\n        });\r\n      this.cd.detectChanges();\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  private send() {\r\n    const data: TerminalPaymentPrepareRequest = this.form.getPaymentValue();\r\n    this.maskedWallet = this.form.maskedWallet;\r\n    this.prepare.emit(data);\r\n  }\r\n\r\n  searchCountry(value) {\r\n    this.countrySearchString = value;\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  get backBtnLabel(): string {\r\n    if (this.step === TerminalStep.Prepare) {\r\n      return I18N_KEY.CONSTRUCTOR_LABEL_CANCEL_RETURN;\r\n    }\r\n    return I18N_KEY.CONSTRUCTOR_LABEL_RETURN;\r\n  }\r\n\r\n  changeTextFieldValue(maskedValue, field: PaymentField) {\r\n    if (field.wallet) {\r\n      this.form.maskedWallet = maskedValue;\r\n      this.cd.markForCheck();\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this.unSubscriber.next();\r\n    this.unSubscriber.unsubscribe();\r\n  }\r\n}\r\n","<form class=\"constructor\"\r\n  [formGroup]=\"form\"\r\n  (ngSubmit)=\"submit()\"\r\n  >\r\n  @if (loading !== null) {\r\n    @if (step === TERMINAL_STEP.Prepare) {\r\n      <div class=\"constructor__fields\">\r\n        @if (countrySearchString || countriesList.length > 1) {\r\n          <div class=\"constructor__field\">\r\n            <app-trm-select [data]=\"countriesList\"\r\n              name=\"country\"\r\n              [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n              formControlName=\"country\"\r\n              class=\"c-field-select trm-form-field\"\r\n              (search)=\"searchCountry($event)\"\r\n              [tabIndex]=\"tabIndex\"\r\n              >\r\n              <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                <span class=\"fi\"\r\n                [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n                <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n              </ng-template>\r\n            </app-trm-select>\r\n          </div>\r\n        }\r\n        @if (form.country.value) {\r\n          <app-ps-select [methods]=\"methodsList\"\r\n            formControlName=\"method\"\r\n            [tabIndex]=\"tabIndex\"\r\n            >\r\n            @if (form.config?.description) {\r\n              <div class=\"constructor__hint text--warn\"\r\n                app-ps-select-hint\r\n                #hintMethod\r\n                @insertRemove\r\n                >\r\n                {{description | trans }}\r\n              </div>\r\n            }\r\n            @if (form.isCDEFailed) {\r\n              <div class=\"constructor__hint cde-error\"\r\n                app-ps-select-hint\r\n                @insertRemove\r\n                >\r\n                {{form.getError('cde_error') | trans }}\r\n              </div>\r\n            }\r\n          </app-ps-select>\r\n        }\r\n        @if (!form.methodInfoLoading) {\r\n          @if (form.paymentFormFieldNames.length) {\r\n            <div formGroupName=\"payment\"\r\n              #paymentRequisites\r\n              class=\"constructor__fields constructor__fields--reverse\">\r\n              @if (form.amountDynamic) {\r\n                <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n              }\r\n              @for (field of form.fields; track field.name; let i = $index) {\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n                  <app-constructor-field-iframe\r\n                    [hidden]=\"form.isCDEFailed\"\r\n                    (paid)=\"cardPaid()\"\r\n                    #cardIframe\r\n                    (error)=\"iframeError($event)\"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n                  </app-constructor-field-iframe>\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n                  <app-constructor-field-select\r\n                    [config]=\"field\"\r\n                    [items]=\"field?.options?.items\"\r\n                    [formControlName]=\"field.name\"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n                  ></app-constructor-field-select>\r\n                }\r\n                @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n                  <app-constructor-field-text\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                    (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n                  [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n                  <app-constructor-field-text\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n                    <app-method-amount-hint app-c-text-hint\r\n                      class=\"constructor__hint\"\r\n                      [loading]=\"feeLoading\"\r\n                      [options]=\"feeOptions || field.options\"\r\n                    ></app-method-amount-hint>\r\n                    <div app-c-text-suffix\r\n                      class=\"constructor__currency\"\r\n                      [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n                      >\r\n                      <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n                    </div>\r\n                  </app-constructor-field-text>\r\n                  @if (hasCurrencyMethodSelector) {\r\n                    <app-trm-select\r\n                      class=\"constructor-field\"\r\n                      [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n                      [formControl]=\"form.currency\"\r\n                      [searchable]=\"false\"\r\n                      [data]=\"currenciesList\"\r\n                      [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n                      >\r\n                      <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                        <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n                        [title]=\"item\"></span>\r\n                        {{item}}\r\n                      </ng-template>\r\n                    </app-trm-select>\r\n                  }\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n                  <app-constructor-field-date\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                  [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n                }\r\n              }\r\n              <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n                <app-trm-select\r\n                  [label]=\"label\"\r\n                  [formControl]=\"form.userCurrency\"\r\n                  [searchable]=\"false\"\r\n                  [data]=\"userCurrenciesList\"\r\n                  [tabIndex]=\"tabIndex\"\r\n                  >\r\n                  <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                    <span class=\"trm-icon\"\r\n                      [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n                    [title]=\"item\"></span>\r\n                    {{item}}\r\n                  </ng-template>\r\n                </app-trm-select>\r\n              </ng-template>\r\n            </div>\r\n          }\r\n        } @else {\r\n          <div class=\"trm-skeleton-fields\">\r\n            @for (i of skeletonLength; track $index) {\r\n              <div class=\"trm-skeleton-field\">\r\n                <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n                <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n              </div>\r\n            }\r\n          </div>\r\n        }\r\n        @if (error && !form.methodInfoLoading) {\r\n          <div class=\"trm-error\"\r\n            @insertRemove\r\n            >\r\n            {{ error | trans }}\r\n          </div>\r\n        }\r\n      </div>\r\n    }\r\n    @if (step === TERMINAL_STEP.Confirmation) {\r\n      <app-constructor-preparation\r\n        [currency]=\"response?.currency\"\r\n        [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n        [wallet]=\"response.wallet\"\r\n        [maskedWallet]=\"maskedWallet\"\r\n        [amount]=\"response.amount\"\r\n        [total]=\"response.total\"\r\n        [confirmationText]=\"form.config?.confirmation\"\r\n        >\r\n        @if (error && !form.payment.pending) {\r\n          <div class=\"trm-error\"\r\n            app-constructor-preparation-error\r\n            @insertRemove\r\n            >\r\n            {{ error | trans }}\r\n          </div>\r\n        }\r\n      </app-constructor-preparation>\r\n    }\r\n    <div class=\"constructor__actions\">\r\n      <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n        type=\"submit\"\r\n        [tabindex]=\"form.fields.length + tabIndex\">\r\n        {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n        @if (loading) {\r\n          <span class=\"trm-spinner trm-spinner-white\"></span>\r\n        }\r\n      </button>\r\n      <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n        type=\"button\"\r\n        [tabindex]=\"form.fields.length + tabIndex\"\r\n      (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n    </div>\r\n  } @else {\r\n    <div class=\"trm-skeleton-group\">\r\n      <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n      <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n    </div>\r\n  }\r\n</form>\r\n"]}
|
|
374
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-form.component.js","sourceRoot":"","sources":["../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/constructor-form.component.ts","../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/constructor-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output,\r\n  QueryList,\r\n  SimpleChanges, TemplateRef,\r\n  ViewChild,\r\n  ViewChildren\r\n} from '@angular/core';\r\nimport { PaymentField, PaymentFieldOptions, PaymentFieldTypeEnum, TerminalStep } from './models';\r\nimport { ConstructorFormService } from './services/constructor-form.service';\r\nimport {\r\n  MethodType,\r\n  MethodTypeType,\r\n  TerminalPaymentConfirmResponse,\r\n  TerminalPaymentPrepareRequest,\r\n  TerminalPaymentPrepareResponse\r\n} from '../../../../codegen/model/models';\r\nimport { insertRemoveTrigger } from './../../../helpers/insertRemoveTrigger';\r\nimport { distinctUntilChanged, Subject } from 'rxjs';\r\nimport { first, takeUntil } from 'rxjs/operators';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { CountriesSortPipe } from '../../../pipes/countries-sort.pipe';\r\nimport { NgScrollbar } from 'ngx-scrollbar';\r\nimport { I18N_KEY } from './../../../i18n';\r\nimport {\r\n  ConstructorFieldIframeComponent\r\n} from \"./components/constructor-field-iframe/constructor-field-iframe.component\";\r\nimport { CountryTranslatePipe } from '../../../pipes/country-translate.pipe';\r\nimport { TERMINAL_VERSION_SERVICE_TOKEN } from '../../../../const';\r\nimport { VersionServiceInterface } from '../../../models';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { NgClass, NgTemplateOutlet } from '@angular/common';\r\nimport { TrmSelectComponent } from '../../../shared/components/trm-select/trm-select.component';\r\nimport {\r\n  TrmSelectLabelTemplateDirective\r\n} from '../../../shared/components/trm-select/trm-select-label-template.directive';\r\nimport { PsSelectComponent } from './components/ps-select/ps-select.component';\r\nimport {\r\n  ConstructorFieldSelectComponent\r\n} from './components/constructor-field-select/constructor-field-select.component';\r\nimport { ConstructorFieldTextComponent } from './components/constructor-field-text/constructor-field-text.component';\r\nimport { MethodAmountHintComponent } from './components/method-amount-hint/method-amount-hint.component';\r\nimport { ConstructorFieldDateComponent } from './components/constructor-field-date/constructor-field-date.component';\r\nimport {\r\n  ConstructorPreparationComponent\r\n} from './components/constructor-preparation/constructor-preparation.component';\r\nimport { TabIndexFocusDirective } from '../../directives/tab-index-focus.directive';\r\nimport { TranslateByKeyPipe } from '../../../shared/pipes/translate-by-key.pipe';\r\nimport { GmSkeletonComponent } from '@gmmoney/gm-ui-kit';\r\nimport { OTHER_COUNTRY_CODE } from \"../../../helpers\";\r\nimport { CardSdkService } from \"./components/constructor-field-iframe/card-sdk.service\";\r\nimport { TerminalTplComponent } from '../../../terminal-tpl.component';\r\n\r\n@Component({\r\n  selector: 'app-constructor-form',\r\n  templateUrl: './constructor-form.component.html',\r\n  styleUrls: ['./constructor-form.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [insertRemoveTrigger],\r\n  providers: [\r\n    ConstructorFormService,\r\n    CountryTranslatePipe, CountriesSortPipe\r\n  ],\r\n  standalone: true,\r\n  imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent]\r\n})\r\nexport class ConstructorFormComponent implements OnChanges, AfterViewInit, OnDestroy {\r\n  private cd = inject(ChangeDetectorRef);\r\n  form = inject(ConstructorFormService);\r\n  private translateSrv = inject(TranslateService);\r\n  private countriesSortPipe = inject(CountriesSortPipe);\r\n  private countryTranslatePipe = inject(CountryTranslatePipe);\r\n  private ngScrollBar = inject(NgScrollbar);\r\n  private versionSrv = inject<VersionServiceInterface>(TERMINAL_VERSION_SERVICE_TOKEN);\r\n\r\n  private unSubscriber = new Subject<void>();\r\n  private preparationStepFilled = false;\r\n  TERMINAL_STEP = TerminalStep;\r\n  @Input() step: TerminalStep;\r\n  @Input() error?: string;\r\n  @Input() response: TerminalPaymentPrepareResponse & TerminalPaymentConfirmResponse & {\r\n    typeId?: number;\r\n  };\r\n  CONSTRUCTOR_FIELD_TYPES = PaymentFieldTypeEnum;\r\n  @Input() feeLoading: boolean;\r\n  @Input() feeOptions: PaymentFieldOptions;\r\n  @Input() currency: string;\r\n  @Input() userCurrency: string[];\r\n  @Input() loading = null;\r\n  @Input() types: MethodType[] = [];\r\n  @Input() canReturnToProject = true;\r\n  @Output() amountChanged: EventEmitter<number> = new EventEmitter<number>();\r\n  @Output() back: EventEmitter<void> = new EventEmitter<void>();\r\n  @Output() prepare: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() confirm: EventEmitter<any> = new EventEmitter<any>();\r\n  @Output() onPaymentChanged: EventEmitter<any> = new EventEmitter<any>();\r\n  @Input() tabIndex: number;\r\n  countrySearchString: string;\r\n  @ViewChild('paymentRequisites', {static: false}) requisites: ElementRef;\r\n  @ViewChild('hintMethod', {static: false}) hintMethod: ElementRef;\r\n  @ViewChildren(CardSdkService) sdkList: QueryList<CardSdkService>;\r\n  maskedWallet: string;\r\n\r\n  I18N_KEY = I18N_KEY;\r\n\r\n  get countriesList(): string[] {\r\n    return this.countriesSortPipe\r\n      .transform(\r\n        this.types\r\n          .map(type => type.countryISOCode)\r\n          .filter((value, index, self) => self.indexOf(value) === index)\r\n      )\r\n      .filter((m: string) => {\r\n        if (!this.countrySearchString) {\r\n          return true;\r\n        } else {\r\n          const title: string = this.countryTranslatePipe.transform(m);\r\n          return title.toLowerCase()\r\n            .split(' ').some(\r\n              ts => this.countrySearchString.toLowerCase().split(' ').some(s => ts.includes(s))\r\n            );\r\n        }\r\n      });\r\n  }\r\n\r\n  get methodsList(): MethodTypeType[] {\r\n    return this.types\r\n      .filter(type => type.countryISOCode === this.form.country.value)\r\n      // distinct\r\n      .filter((type, index, self) => self.map(m => m.type.id).indexOf(type.type.id) === index)\r\n      //sorting by the priority\r\n      .sort((m1, m2) => m1.priority > m2.priority ? 1 : ((m1.priority === m2.priority) ? 0 : -1))\r\n      .map(type => type.type);\r\n  }\r\n\r\n  get currenciesList() {\r\n    return this.types\r\n      .filter(type => type.countryISOCode === this.form.country.value && type.type.id === this.form.method.value)\r\n      .map(type => type.currency)\r\n  }\r\n\r\n  get userCurrenciesList() {\r\n    const filteredTypes = this.currenciesList;\r\n\r\n    if (!this.userCurrency) {\r\n      return filteredTypes;\r\n    }\r\n\r\n    return this.userCurrency\r\n      .filter(userCurrency => filteredTypes.includes(userCurrency))\r\n  }\r\n\r\n  private setCurrencyValue() {\r\n    let defaultCurrency = this.form.defaultCurrency;\r\n\r\n    let currencies = this.currenciesList;\r\n    let currency = currencies[0];\r\n    if (defaultCurrency && this.currenciesList.includes(defaultCurrency)) {\r\n      currency = defaultCurrency;\r\n    } else if (this.currency && this.currenciesList.includes(this.currency)) {\r\n      currency = this.currency;\r\n    }\r\n    this.form.currency.setValue(currency);\r\n\r\n    currencies = this.userCurrenciesList;\r\n    currency = currencies[0];\r\n    if (defaultCurrency && this.userCurrenciesList.includes(defaultCurrency)) {\r\n      currency = defaultCurrency;\r\n    } else if (this.currency && this.userCurrenciesList.includes(this.currency)) {\r\n      currency = this.currency;\r\n    }\r\n    this.form.userCurrency.setValue(currency, {emitEvent: false});\r\n    if (currencies.length === 1 && currency && this.form.method.disabled) {\r\n      this.form.userCurrency.disable();\r\n    }\r\n  }\r\n\r\n  get hasCurrencyMethodSelector(): boolean {\r\n    return this.versionSrv.hasCurrencyMethodSelector === true;\r\n  }\r\n\r\n  get lang(): string {\r\n    return this.translateSrv.currentLang;\r\n  }\r\n\r\n  get skeletonLength() {\r\n    return new Array(this.form.fields?.length || 3).fill(0);\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    if (changes.types && this.types?.length || changes.currency && this.currency) {\r\n      // Get configuration fields\r\n      const countries = this.countriesList;\r\n      const defaultCountry = this.form.defaultCountry;\r\n      let country = null;\r\n      if (!countries.includes(defaultCountry)) {\r\n        if (countries.includes(OTHER_COUNTRY_CODE)) {\r\n          country = OTHER_COUNTRY_CODE;\r\n        }\r\n      } else {\r\n        country = defaultCountry;\r\n      }\r\n      this.form.country.setValue(country);\r\n      if (!country) {\r\n        return;\r\n      }\r\n      if (countries.length === 1 && this.form.country.value) {\r\n        this.form.country.disable();\r\n      }\r\n\r\n      const methods = this.methodsList;\r\n      const defaultMethodName = this.form.defaultMethodName;\r\n      const defaultMethod = methods.find(m => m.name === defaultMethodName)?.id;\r\n      this.form.method.setValue(defaultMethod || methods[0]?.id);\r\n\r\n      this.cd.detectChanges();\r\n      if (methods.length === 1 && this.form.country.disabled) {\r\n        this.form.method.disable();\r\n      }\r\n      this.cd.detectChanges();\r\n      this.setCurrencyValue();\r\n      this.cd.detectChanges();\r\n\r\n      this.form\r\n        .distinctValueChanges()\r\n        .pipe(\r\n          takeUntil(this.unSubscriber)\r\n        )\r\n        .subscribe(() => this.onPaymentChanged.emit(this.form.getRawValue()));\r\n      this.fetchForm();\r\n    }\r\n\r\n    if (changes.step?.currentValue && !changes.types && !changes.currency) {\r\n      this.fetchForm();\r\n    }\r\n\r\n    if (changes.feeOptions && !changes.feeOptions.firstChange) {\r\n      // need for triggering of the custom validator\r\n      this.form.amount?.updateValueAndValidity();\r\n    }\r\n\r\n    if (this.step === TerminalStep.Confirmation) {\r\n      this.preparationStepFilled = true;\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.form\r\n      .country\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.cd.detectChanges();\r\n        this.form.saveDefaultCountry();\r\n        this.form.method.setValue(this.methodsList[0].id, {emitEvent: false});\r\n\r\n        const methods = this.methodsList;\r\n        const defaultMethodName = this.form.defaultMethodName;\r\n        const defaultMethod = methods.find(m => m.name === defaultMethodName)?.id;\r\n        this.form.method.setValue(defaultMethod || methods[0].id, {emitEvent: false});\r\n        this.cd.detectChanges();\r\n\r\n        this.setCurrencyValue();\r\n        this.cd.detectChanges();\r\n\r\n        this.fetchForm();\r\n      });\r\n    this.form\r\n      .method\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.form.method.clearValidators();\r\n        this.form.saveDefaultMethodName();\r\n        this.setCurrencyValue();\r\n        this.cd.detectChanges();\r\n        this.fetchForm();\r\n      })\r\n    this.form\r\n      .currency\r\n      .valueChanges\r\n      .pipe(\r\n        distinctUntilChanged((a, b) => a === b),\r\n        takeUntil(this.unSubscriber)\r\n      )\r\n      .subscribe(() => {\r\n        this.fetchForm();\r\n        this.form.saveDefaultCurrency();\r\n      });\r\n  }\r\n\r\n  private fetchForm() {\r\n    if (!this.form.method.value) {\r\n      this.form.ready = true;\r\n      return;\r\n    }\r\n    this.form.cancelRequests();\r\n    if (this.step !== this.TERMINAL_STEP.Prepare) {\r\n      return;\r\n    }\r\n    this.form.removePaymentFormControls();\r\n    this.cd.detectChanges();\r\n    this.form\r\n      .init()\r\n      .subscribe(() => {\r\n        if (!this.preparationStepFilled && !this.form.hasWhatToFill()) {\r\n          this.send();\r\n          return;\r\n        }\r\n        this.form.payment.updateValueAndValidity({ onlySelf: true });\r\n        this.cd.detectChanges();\r\n        this.scrollToRequisits();\r\n        this.form.maskedWallet = '';\r\n      }, (err) => {\r\n        this.form.payment.updateValueAndValidity({ onlySelf: true });\r\n        this.cd.markForCheck();\r\n      });\r\n  }\r\n\r\n  private scrollToRequisits() {\r\n    if (this.requisites || this.hintMethod) {\r\n      this.ngScrollBar?.scrollToElement(this.hintMethod?.nativeElement || this.requisites.nativeElement, {\r\n        duration: 500,\r\n        top: -75\r\n      });\r\n    }\r\n  }\r\n\r\n  get description() {\r\n    return typeof this.form.config?.description === 'function' ? this.form.config?.description(this.form.getRawValue()) : this.form.config?.description;\r\n  }\r\n\r\n  submit() {\r\n    if (this.feeLoading) {\r\n      return;\r\n    }\r\n    if (this.step === TerminalStep.Confirmation) {\r\n      this.confirm.emit();\r\n      return;\r\n    }\r\n\r\n    if (this.form.config === null || !this.form.ready) {\r\n      return;\r\n    }\r\n    this.triggerIframeSubmit();\r\n    if (this.form.invalid || this.error) {\r\n      Object.values(this.form.controls).forEach((control) => {\r\n        control.markAsDirty();\r\n        control.markAsTouched();\r\n      });\r\n      Object.values(this.form.payment.controls).forEach((control) => {\r\n        control.markAsDirty();\r\n        control.markAsTouched();\r\n        control.updateValueAndValidity({ emitEvent: false });\r\n      });\r\n      this.cd.detectChanges();\r\n      return;\r\n    }\r\n\r\n    if (this.form.pending) {\r\n      this.form.statusChanges\r\n        .pipe(first(), takeUntil(this.unSubscriber))\r\n        .subscribe((status) => {\r\n          if (status === 'VALID') {\r\n            this.send();\r\n          }\r\n        });\r\n    } else {\r\n      this.send();\r\n    }\r\n  }\r\n\r\n  private triggerIframeSubmit() {\r\n    if (!this.form.readyIframesSubmit) {\r\n      return;\r\n    }\r\n    this.sdkList?.forEach((sdk: CardSdkService) => sdk.submit());\r\n    this.form.updateValueAndValidityIframes();\r\n  }\r\n\r\n  private send() {\r\n    const data: TerminalPaymentPrepareRequest = this.form.getPaymentValue();\r\n    this.maskedWallet = this.form.maskedWallet;\r\n    this.prepare.emit(data);\r\n  }\r\n\r\n  searchCountry(value) {\r\n    this.countrySearchString = value;\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  get backBtnLabel(): string {\r\n    if (this.step === TerminalStep.Prepare) {\r\n      return I18N_KEY.CONSTRUCTOR_LABEL_CANCEL_RETURN;\r\n    }\r\n    return I18N_KEY.CONSTRUCTOR_LABEL_RETURN;\r\n  }\r\n\r\n  changeTextFieldValue(maskedValue, field: PaymentField) {\r\n    if (field.wallet) {\r\n      this.form.maskedWallet = maskedValue;\r\n      this.cd.markForCheck();\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy() {\r\n    this.unSubscriber.next();\r\n    this.unSubscriber.unsubscribe();\r\n  }\r\n}\r\n","<form class=\"constructor\"\r\n  [formGroup]=\"form\"\r\n  (ngSubmit)=\"submit()\"\r\n  >\r\n  @if (loading !== null) {\r\n    @if (step === TERMINAL_STEP.Prepare) {\r\n      <div class=\"constructor__fields\">\r\n        @if (countrySearchString || countriesList.length > 1) {\r\n          <div class=\"constructor__field\">\r\n            <app-trm-select [data]=\"countriesList\"\r\n                            @insertRemove\r\n              name=\"country\"\r\n              [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n              formControlName=\"country\"\r\n              class=\"c-field-select trm-form-field\"\r\n              (search)=\"searchCountry($event)\"\r\n              [tabIndex]=\"tabIndex\"\r\n              >\r\n              <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                <span class=\"fi\"\r\n                [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n                <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n              </ng-template>\r\n            </app-trm-select>\r\n          </div>\r\n        }\r\n        @if (form.country.value) {\r\n          <app-ps-select [methods]=\"methodsList\"\r\n                         @insertRemove\r\n            formControlName=\"method\"\r\n            [tabIndex]=\"tabIndex\"\r\n            >\r\n            @if (form.config?.description) {\r\n              <div class=\"constructor__hint text--warn\"\r\n                app-ps-select-hint\r\n                #hintMethod\r\n                @insertRemove\r\n                >\r\n                {{description | trans }}\r\n              </div>\r\n            }\r\n          </app-ps-select>\r\n\r\n          @if (\r\n            form.method?.hasError('required') &&\r\n            form.method.touched &&\r\n            form.method.dirty\r\n            ) {\r\n            <div class=\"gm-error\" @insertRemove>\r\n              {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n            </div>\r\n          }\r\n        }\r\n\r\n        @if (form.ready) {\r\n            <div formGroupName=\"payment\"\r\n                 @insertRemove\r\n              #paymentRequisites\r\n              class=\"constructor__fields constructor__fields--reverse\">\r\n              @if (form.method.value && form.amountDynamic) {\r\n                <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n              }\r\n              @for (field of form.fields; track field.name; let i = $index) {\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n                  @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n                    <div class=\"constructor__hint cde-error\" @insertRemove>\r\n                      {{\r\n                        form.payment.get(field.name).getError('cde_error')\r\n                          | trans\r\n                      }}\r\n                    </div>\r\n                  }\r\n                  <app-constructor-field-iframe\r\n                    [formControlName]=\"field.name\"\r\n                    @insertRemove\r\n                    [hidden]=\"\r\n                        form.payment.get(field.name)?.hasError('cde_error')\r\n                      \"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n                  >\r\n                  </app-constructor-field-iframe>\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n                  <app-constructor-field-select\r\n                    @insertRemove\r\n                    [config]=\"field\"\r\n                    [items]=\"field?.options?.items\"\r\n                    [formControlName]=\"field.name\"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n                  ></app-constructor-field-select>\r\n                }\r\n                @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n                  <app-constructor-field-text\r\n                    @insertRemove\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                    (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n                  [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n                  <app-constructor-field-text\r\n                    @insertRemove\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                    [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n                    <app-method-amount-hint app-c-text-hint\r\n                      class=\"constructor__hint\"\r\n                      [loading]=\"feeLoading\"\r\n                      [options]=\"feeOptions || field.options\"\r\n                    ></app-method-amount-hint>\r\n                    <div app-c-text-suffix\r\n                      class=\"constructor__currency\"\r\n                      [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n                      >\r\n                      <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n                    </div>\r\n                  </app-constructor-field-text>\r\n                  @if (hasCurrencyMethodSelector) {\r\n                    <app-trm-select\r\n                      @insertRemove\r\n                      class=\"constructor-field\"\r\n                      [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n                      [formControl]=\"form.currency\"\r\n                      [searchable]=\"false\"\r\n                      [data]=\"currenciesList\"\r\n                      [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n                      >\r\n                      <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                        <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n                        [title]=\"item\"></span>\r\n                        {{item}}\r\n                      </ng-template>\r\n                    </app-trm-select>\r\n                  }\r\n                }\r\n                @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n                  <app-constructor-field-date\r\n                    @insertRemove\r\n                    [config]=\"field\"\r\n                    [formControlName]=\"field.name\"\r\n                  [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n                }\r\n              }\r\n              <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n                <app-trm-select\r\n                  @insertRemove\r\n                  [label]=\"label\"\r\n                  [formControl]=\"form.userCurrency\"\r\n                  [searchable]=\"false\"\r\n                  [data]=\"userCurrenciesList\"\r\n                  [tabIndex]=\"tabIndex\"\r\n                  >\r\n                  <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n                    <span class=\"trm-icon\"\r\n                      [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n                    [title]=\"item\"></span>\r\n                    {{item}}\r\n                  </ng-template>\r\n                </app-trm-select>\r\n              </ng-template>\r\n            </div>\r\n        } @else {\r\n          <div class=\"trm-skeleton-fields\">\r\n            @for (i of skeletonLength; track $index) {\r\n              <div class=\"trm-skeleton-field\">\r\n                <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n                <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n              </div>\r\n            }\r\n          </div>\r\n        }\r\n        @if (error && !form.methodInfoLoading) {\r\n          <div class=\"trm-error\"\r\n            @insertRemove\r\n            >\r\n            {{ error | trans }}\r\n          </div>\r\n        }\r\n      </div>\r\n    }\r\n    @if (step === TERMINAL_STEP.Confirmation) {\r\n      <app-constructor-preparation\r\n        @insertRemove\r\n        [currency]=\"response?.currency\"\r\n        [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n        [wallet]=\"response.wallet\"\r\n        [maskedWallet]=\"maskedWallet\"\r\n        [amount]=\"response.amount\"\r\n        [total]=\"response.total\"\r\n        [confirmationText]=\"form.config?.confirmation\"\r\n        >\r\n        @if (error && !form.payment.pending) {\r\n          <div class=\"trm-error\"\r\n            app-constructor-preparation-error\r\n            @insertRemove\r\n            >\r\n            {{ error | trans }}\r\n          </div>\r\n        }\r\n      </app-constructor-preparation>\r\n    }\r\n    <div class=\"constructor__actions\"\r\n         @insertRemove>\r\n      <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n        type=\"submit\"\r\n        [tabindex]=\"form.fields.length + tabIndex\">\r\n        {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n        @if (loading) {\r\n          <span class=\"trm-spinner trm-spinner-white\"></span>\r\n        }\r\n      </button>\r\n      <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n        type=\"button\"\r\n        [tabindex]=\"form.fields.length + tabIndex\"\r\n      (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n    </div>\r\n  } @else {\r\n    <div class=\"trm-skeleton-group\">\r\n      <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n      <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n    </div>\r\n  }\r\n</form>\r\n"]}
|