trm-tmpl 3.2.1 → 3.2.2
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 +102 -118
- 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/ps-select/ps-select.component.mjs +20 -24
- package/esm2022/lib/app/pages/components/constructor-form/constructor-form.component.mjs +89 -66
- 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.mjs +1 -1
- package/esm2022/lib/app/pages/components/constructor-form/services/constructor-form.service.mjs +39 -24
- package/esm2022/lib/app/pages/components/terminal-layout/terminal-layout.component.mjs +11 -9
- 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 +8 -8
- 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 +5 -12
- package/fesm2022/trm-tmpl.mjs +738 -587
- 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 +25 -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/ps-select/ps-select.component.d.ts +4 -6
- package/lib/app/pages/components/constructor-form/constructor-form.component.d.ts +5 -8
- package/lib/app/pages/components/constructor-form/models/index.d.ts +0 -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/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/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,141 +1,125 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component,
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import { SessionDataSource } from
|
|
7
|
-
import { ScriptLoader } from '../../../../../services';
|
|
1
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, forwardRef, inject, Injector, Input, } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
+
import { NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';
|
|
4
|
+
import { I18N_KEY } from '../../../../../i18n';
|
|
5
|
+
import { TranslateService } from '@ngx-translate/core';
|
|
6
|
+
import { SessionDataSource } from '../../../../../services/session.data-source';
|
|
8
7
|
import { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';
|
|
9
|
-
import {
|
|
8
|
+
import { CardSdkService } from './card-sdk.service';
|
|
9
|
+
import { IframeValidatorDirectiveDirective } from './iframe-validator-directive.directive';
|
|
10
|
+
import { insertRemoveTrigger } from "../../../../../helpers";
|
|
11
|
+
import { GmSkeletonComponent } from "@gmmoney/gm-ui-kit";
|
|
10
12
|
import * as i0 from "@angular/core";
|
|
13
|
+
import * as i1 from "./iframe-validator-directive.directive";
|
|
14
|
+
const ID_CDE_CONTAINER = 'cde-container';
|
|
11
15
|
export class ConstructorFieldIframeComponent {
|
|
12
|
-
get finished() {
|
|
13
|
-
return this._finished;
|
|
14
|
-
}
|
|
15
16
|
constructor() {
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
17
|
+
this._translateSrv = inject(TranslateService);
|
|
18
|
+
this._sessionSrv = inject(SessionDataSource);
|
|
19
|
+
this._cd = inject(ChangeDetectorRef);
|
|
20
|
+
this._injector = inject(Injector);
|
|
21
|
+
this._destroyRef = inject(DestroyRef);
|
|
22
|
+
this.viewReady = false;
|
|
23
|
+
this.validator = inject(IframeValidatorDirectiveDirective);
|
|
24
|
+
this.cardSdkSrv = inject(CardSdkService);
|
|
25
|
+
this._loading = true;
|
|
23
26
|
this.I18N_KEY = I18N_KEY;
|
|
24
|
-
this.
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
this._ready = false;
|
|
32
|
-
this._finished = false;
|
|
33
|
-
this.submitted = false;
|
|
27
|
+
this.ID_CDE_CONTAINER = ID_CDE_CONTAINER;
|
|
28
|
+
}
|
|
29
|
+
registerOnTouched(fn) { }
|
|
30
|
+
registerOnChange(fn) { }
|
|
31
|
+
writeValue() { }
|
|
32
|
+
get loading() {
|
|
33
|
+
return this._loading;
|
|
34
34
|
}
|
|
35
35
|
ngAfterViewInit() {
|
|
36
|
-
this.
|
|
37
|
-
|
|
38
|
-
.
|
|
36
|
+
this._control = this._injector.get(NgControl).control;
|
|
37
|
+
this.cardSdkSrv
|
|
38
|
+
.createCardTerminalSdk$(this._translateSrv.currentLang, this.ID_CDE_CONTAINER, this.tabIndex)
|
|
39
|
+
.pipe(takeUntilDestroyed(this._destroyRef))
|
|
40
|
+
.subscribe({
|
|
41
|
+
next: (sdk) => {
|
|
42
|
+
this._sdk = sdk;
|
|
43
|
+
this._destroyRef.onDestroy(() => this._sdk?.unsubscribe());
|
|
44
|
+
this.validator.registerSDK(sdk);
|
|
45
|
+
this._init();
|
|
46
|
+
},
|
|
47
|
+
error: () => {
|
|
48
|
+
this.validator.registerSDK();
|
|
49
|
+
this._updateValueAndValidity();
|
|
50
|
+
},
|
|
51
|
+
});
|
|
39
52
|
}
|
|
40
|
-
|
|
41
|
-
|
|
53
|
+
_updateValueAndValidity() {
|
|
54
|
+
this.cardSdkSrv.markAsReady();
|
|
55
|
+
this._control?.updateValueAndValidity({ onlySelf: true });
|
|
56
|
+
this._cd.detectChanges();
|
|
57
|
+
this.refreshHeight();
|
|
42
58
|
}
|
|
43
|
-
|
|
44
|
-
|
|
59
|
+
refreshHeight() {
|
|
60
|
+
setTimeout(() => {
|
|
61
|
+
this._sdk?.refreshHeight();
|
|
62
|
+
this.viewReady = true;
|
|
63
|
+
this._cd.detectChanges();
|
|
64
|
+
}, 100);
|
|
45
65
|
}
|
|
46
66
|
_init() {
|
|
47
|
-
this._sdk = this.sessionSrv.createCardTerminalSdk(this.lang, this.ID_CDE_CONTAINER, this.tabIndex);
|
|
48
|
-
if (!this.iframe) {
|
|
49
|
-
this._onError();
|
|
50
|
-
return;
|
|
51
|
-
}
|
|
52
|
-
this.iframe
|
|
53
|
-
.addEventListener('load', this._iframeOnLoadHandler);
|
|
54
|
-
this._sdk
|
|
55
|
-
.onError((code) => this._onError(code));
|
|
56
67
|
this._sdk.onInputPending(() => {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
});
|
|
60
|
-
this._ready = false;
|
|
68
|
+
this._loading = false;
|
|
69
|
+
this._updateValueAndValidity();
|
|
61
70
|
});
|
|
62
|
-
this._sdk.onInputReady(() =>
|
|
63
|
-
|
|
64
|
-
.onInputSubmitted(() => {
|
|
65
|
-
this._finished = true;
|
|
66
|
-
if (this.submitted) {
|
|
67
|
-
this.status = I18N_KEY.CDE_CARD_PAID;
|
|
68
|
-
this.paid.emit();
|
|
69
|
-
}
|
|
70
|
-
else {
|
|
71
|
-
this.status = I18N_KEY.CDE_CARD_ERROR_ALREADY_PAID;
|
|
72
|
-
}
|
|
73
|
-
this.cd.detectChanges();
|
|
71
|
+
this._sdk.onInputReady(() => {
|
|
72
|
+
this._updateValueAndValidity();
|
|
74
73
|
});
|
|
75
|
-
this._sdk
|
|
76
|
-
.
|
|
77
|
-
|
|
78
|
-
.
|
|
79
|
-
.
|
|
80
|
-
.subscribe((options) => {
|
|
81
|
-
if (!options.lang) {
|
|
82
|
-
return;
|
|
83
|
-
}
|
|
84
|
-
this._sdk.useLang(options.lang);
|
|
74
|
+
this._sdk.onInputSubmitted(() => {
|
|
75
|
+
this._loading = false;
|
|
76
|
+
this.cardSdkSrv.markAsSubmitted();
|
|
77
|
+
this.status = I18N_KEY.CDE_CARD_ERROR_ALREADY_PAID;
|
|
78
|
+
this._updateValueAndValidity();
|
|
85
79
|
});
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
subscriptions.map(s => s.unsubscribe());
|
|
103
|
-
return result;
|
|
80
|
+
this._sdk.onTimeout(() => {
|
|
81
|
+
this._updateValueAndValidity();
|
|
82
|
+
});
|
|
83
|
+
this._sdk.onError(() => {
|
|
84
|
+
this._loading = false;
|
|
85
|
+
this._updateValueAndValidity();
|
|
86
|
+
});
|
|
87
|
+
this._translateSrv.onLangChange
|
|
88
|
+
.pipe(takeUntilDestroyed(this._destroyRef))
|
|
89
|
+
.subscribe({
|
|
90
|
+
next: (options) => {
|
|
91
|
+
if (!options.lang) {
|
|
92
|
+
return;
|
|
93
|
+
}
|
|
94
|
+
this._sdk.useLang(options.lang);
|
|
95
|
+
},
|
|
104
96
|
});
|
|
105
|
-
}
|
|
106
|
-
_onError(code) {
|
|
107
|
-
let codeError = I18N_KEY.ERROR_OCCUR;
|
|
108
|
-
if (code === 501) {
|
|
109
|
-
codeError = I18N_KEY.CDE_CARD_ERROR_501;
|
|
110
|
-
}
|
|
111
|
-
else if (code === 500) {
|
|
112
|
-
codeError = I18N_KEY.CDE_CARD_ERROR_500;
|
|
113
|
-
}
|
|
114
|
-
else if (code === 504) {
|
|
115
|
-
codeError = I18N_KEY.CDE_CARD_ERROR_504;
|
|
116
|
-
}
|
|
117
|
-
this.loading = false;
|
|
118
|
-
this.error.emit(codeError);
|
|
119
|
-
}
|
|
120
|
-
ngOnDestroy() {
|
|
121
|
-
this.iframe?.removeEventListener('load', this._iframeOnLoadHandler);
|
|
122
|
-
this.unSubscriber.next();
|
|
123
|
-
this.unSubscriber.unsubscribe();
|
|
124
|
-
this._sdk?.unsubscribe();
|
|
125
97
|
}
|
|
126
98
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldIframeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
127
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ConstructorFieldIframeComponent, isStandalone: true, selector: "app-constructor-field-iframe", inputs: { tabIndex: "tabIndex" },
|
|
99
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ConstructorFieldIframeComponent, isStandalone: true, selector: "app-constructor-field-iframe", inputs: { tabIndex: "tabIndex" }, providers: [
|
|
100
|
+
{
|
|
101
|
+
provide: NG_VALUE_ACCESSOR,
|
|
102
|
+
useExisting: forwardRef(() => ConstructorFieldIframeComponent),
|
|
103
|
+
multi: true,
|
|
104
|
+
},
|
|
105
|
+
CardSdkService,
|
|
106
|
+
], hostDirectives: [{ directive: i1.IframeValidatorDirectiveDirective }], ngImport: i0, template: "@if (!status) {\r\n <div\r\n class=\"iframe-container\"\r\n [id]=\"ID_CDE_CONTAINER\"\r\n [hidden]=\"loading\"\r\n [class.iframe-container--ready]=\"viewReady\"\r\n ></div>\r\n} @else if (!loading) {\r\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\r\n}\r\n\r\n@if (loading) {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of [1,2]; track i) {\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", styles: [":host{position:relative}.iframe-container{position:absolute;width:100%;visibility:hidden}.iframe-container--ready{position:relative;visibility:visible}.iframe-warning{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}\n"], dependencies: [{ 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 }); }
|
|
128
107
|
}
|
|
129
108
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldIframeComponent, decorators: [{
|
|
130
109
|
type: Component,
|
|
131
|
-
args: [{ selector: 'app-constructor-field-iframe', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true,
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
110
|
+
args: [{ selector: 'app-constructor-field-iframe', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, animations: [insertRemoveTrigger], providers: [
|
|
111
|
+
{
|
|
112
|
+
provide: NG_VALUE_ACCESSOR,
|
|
113
|
+
useExisting: forwardRef(() => ConstructorFieldIframeComponent),
|
|
114
|
+
multi: true,
|
|
115
|
+
},
|
|
116
|
+
CardSdkService,
|
|
117
|
+
], imports: [TranslateByKeyPipe, GmSkeletonComponent], hostDirectives: [
|
|
118
|
+
{
|
|
119
|
+
directive: IframeValidatorDirectiveDirective,
|
|
120
|
+
},
|
|
121
|
+
], template: "@if (!status) {\r\n <div\r\n class=\"iframe-container\"\r\n [id]=\"ID_CDE_CONTAINER\"\r\n [hidden]=\"loading\"\r\n [class.iframe-container--ready]=\"viewReady\"\r\n ></div>\r\n} @else if (!loading) {\r\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\r\n}\r\n\r\n@if (loading) {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of [1,2]; track i) {\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", styles: [":host{position:relative}.iframe-container{position:absolute;width:100%;visibility:hidden}.iframe-container--ready{position:relative;visibility:visible}.iframe-warning{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}\n"] }]
|
|
122
|
+
}], propDecorators: { tabIndex: [{
|
|
139
123
|
type: Input
|
|
140
124
|
}] } });
|
|
141
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-iframe.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,MAAM,EACN,KAAK,EAEL,MAAM,EACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAmB,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAEhF,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAEvD,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;AACvF,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;;AAUzD,MAAM,OAAO,+BAA+B;IAuBxC,IAAI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;QA1BQ,iBAAY,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACxC,eAAU,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACvC,OAAE,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC/B,oBAAe,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;QAEtC,qBAAgB,GAAG,eAAe,CAAC;QAEpC,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAC3C,YAAO,GAAG,IAAI,CAAC;QAEf,aAAQ,GAAG,QAAQ,CAAC;QACV,UAAK,GAAG,IAAI,YAAY,EAAY,CAAC;QACrC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAChC,UAAK,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEnC,yBAAoB,GAAe,GAAG,EAAE;YAC5C,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC5B,CAAC,CAAA;QACO,WAAM,GAAG,KAAK,CAAC;QAEf,cAAS,GAAG,KAAK,CAAC;QAoElB,cAAS,GAAG,KAAK,CAAC;IA9D1B,CAAC;IAED,eAAe;QACb,IAAI,CAAC,eAAe;aACjB,WAAW,CAAC,SAAS,CAAC;aACtB,IAAI,CACH,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAClB,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CACtB,CAAC;IACN,CAAC;IAED,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC;IACzC,CAAC;IAED,IAAY,MAAM;QACd,OAAO,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC;IAC7B,CAAC;IAEO,KAAK;QACT,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACnG,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;YACjB,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO;QACT,CAAC;QACD,IAAI,CAAC,MAAM;aACN,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACzD,IAAI,CAAC,IAAI;aACJ,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC;QAC5C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE;YAC5B,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YAC5B,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACtB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;QACjD,IAAI,CAAC,IAAI;aACJ,gBAAgB,CAAC,GAAG,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC;gBACrC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACrB,CAAC;iBAAM,CAAC;gBACJ,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC,2BAA2B,CAAC;YACvD,CAAC;YACD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QACP,IAAI,CAAC,IAAI;aACJ,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,kBAAkB,CAAC,CAAC,CAAC;QACnE,IAAI,CAAC,YAAY;aACZ,YAAY;aACZ,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAC/B;aACA,SAAS,CAAC,CAAC,OAAwB,EAAE,EAAE;YACpC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;gBAChB,OAAO;YACX,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACpC,CAAC,CAAC,CAAC;IACX,CAAC;IAID,MAAM;QACF,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,MAAM,aAAa,GAAgC,EAAE,CAAC;QACtD,OAAO,IAAI,OAAO,CAAU,CAAC,OAAO,EAAE,EAAE;YACtC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;gBACjB,OAAO,CAAC,KAAK,CAAC,CAAC;YACjB,CAAC;iBAAM,CAAC;gBACN,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBACnE,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;gBAC5D,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YACtE,CAAC;YACD,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;QACrB,CAAC,CAAC;aACC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;YACf,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;YACxC,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC,CAAC;IACT,CAAC;IAEO,QAAQ,CAAC,IAAsB;QACnC,IAAI,SAAS,GAAG,QAAQ,CAAC,WAAW,CAAC;QACrC,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;YACjB,SAAS,GAAG,QAAQ,CAAC,kBAAkB,CAAC;QAC1C,CAAC;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;YACxB,SAAS,GAAG,QAAQ,CAAC,kBAAkB,CAAC;QAC1C,CAAC;aAAM,IAAI,IAAI,KAAK,GAAG,EAAE,CAAC;YACxB,SAAS,GAAG,QAAQ,CAAC,kBAAkB,CAAC;QAC1C,CAAC;QACD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC/B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,MAAM,EAAE,mBAAmB,CAAC,MAAM,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;QACpE,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC;QAChC,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,CAAC;IAC7B,CAAC;8GAjIQ,+BAA+B;kGAA/B,+BAA+B,qLC9B5C,+gBAkBA,kKDUY,kBAAkB,8CAAE,mBAAmB;;2FAEtC,+BAA+B;kBAR3C,SAAS;+BACI,8BAA8B,mBAGvB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACT,CAAC,kBAAkB,EAAE,mBAAmB,CAAC;wDActC,KAAK;sBAAd,MAAM;gBACG,IAAI;sBAAb,MAAM;gBACG,KAAK;sBAAd,MAAM;gBACE,QAAQ;sBAAhB,KAAK","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnDestroy,\r\n  Output\r\n} from '@angular/core';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { LangChangeEvent, TranslateService } from \"@ngx-translate/core\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\nimport { Subject } from \"rxjs\";\r\nimport { SessionDataSource } from \"../../../../../services/session.data-source\";\r\nimport { CdeTerminalSdk } from '../../../../../models';\r\nimport { ScriptLoader } from '../../../../../services';\r\n\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-field-iframe',\r\n    templateUrl: './constructor-field-iframe.component.html',\r\n    styleUrls: ['./constructor-field-iframe.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n  imports: [TranslateByKeyPipe, GmSkeletonComponent]\r\n})\r\nexport class ConstructorFieldIframeComponent implements AfterViewInit, OnDestroy {\r\n    private translateSrv = inject(TranslateService);\r\n    private sessionSrv = inject(SessionDataSource);\r\n    private cd = inject(ChangeDetectorRef);\r\n    private scriptLoaderSrv = inject(ScriptLoader);\r\n\r\n    readonly ID_CDE_CONTAINER = 'cde-container';\r\n    private _sdk: CdeTerminalSdk;\r\n    private unSubscriber = new Subject<void>();\r\n    loading = true;\r\n    status: I18N_KEY;\r\n    I18N_KEY = I18N_KEY;\r\n    @Output() error = new EventEmitter<I18N_KEY>();\r\n    @Output() paid = new EventEmitter<void>();\r\n    @Output() ready = new EventEmitter<void>();\r\n    @Input() tabIndex;\r\n    private _iframeOnLoadHandler: () => void = () => {\r\n        this.loading = false;\r\n        this.cd.detectChanges();\r\n    }\r\n    private _ready = false;\r\n\r\n    private _finished = false;\r\n    get finished() {\r\n        return this._finished;\r\n    }\r\n\r\n    constructor() {\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n      this.scriptLoaderSrv\r\n        .fetchScript('cde_sdk')\r\n        .then(\r\n          () => this._init(),\r\n          () => this._onError()\r\n        );\r\n    }\r\n\r\n    get lang() {\r\n        return this.translateSrv.currentLang;\r\n    }\r\n\r\n    private get iframe(): HTMLIFrameElement {\r\n        return this._sdk?.iframe;\r\n    }\r\n\r\n    private _init() {\r\n        this._sdk = this.sessionSrv.createCardTerminalSdk(this.lang, this.ID_CDE_CONTAINER, this.tabIndex);\r\n        if (!this.iframe) {\r\n          this._onError();\r\n          return;\r\n        }\r\n        this.iframe\r\n            .addEventListener('load', this._iframeOnLoadHandler);\r\n        this._sdk\r\n            .onError((code) => this._onError(code));\r\n        this._sdk.onInputPending(() => {\r\n          setTimeout(() => {\r\n            this._sdk.refreshHeight();\r\n          });\r\n          this._ready = false;\r\n        });\r\n        this._sdk.onInputReady(() => this._ready = true);\r\n        this._sdk\r\n            .onInputSubmitted(() => {\r\n                this._finished = true;\r\n                if (this.submitted) {\r\n                    this.status = I18N_KEY.CDE_CARD_PAID;\r\n                    this.paid.emit();\r\n                } else {\r\n                    this.status = I18N_KEY.CDE_CARD_ERROR_ALREADY_PAID;\r\n                }\r\n                this.cd.detectChanges();\r\n            });\r\n        this._sdk\r\n            .onTimeout(() => this.error.emit(I18N_KEY.CDE_CARD_ERROR_504));\r\n        this.translateSrv\r\n            .onLangChange\r\n            .pipe(\r\n                takeUntil(this.unSubscriber)\r\n            )\r\n            .subscribe((options: LangChangeEvent) => {\r\n                if (!options.lang) {\r\n                    return;\r\n                }\r\n                this._sdk.useLang(options.lang);\r\n            });\r\n    }\r\n\r\n    private submitted = false;\r\n\r\n    submit() {\r\n        this.submitted = true;\r\n        const subscriptions: {unsubscribe: () => void}[] = [];\r\n        return new Promise<boolean>((resolve) => {\r\n          if (!this._ready) {\r\n            resolve(false);\r\n          } else {\r\n            subscriptions.push(this._sdk.onInputPending(() => resolve(false)));\r\n            subscriptions.push(this._sdk.onError(() => resolve(false)));\r\n            subscriptions.push(this._sdk.onInputSubmitted(() => resolve(true)));\r\n          }\r\n          this._sdk.submit();\r\n        })\r\n          .then((result) => {\r\n            subscriptions.map(s => s.unsubscribe());\r\n            return result;\r\n          });\r\n    }\r\n\r\n    private _onError(code?: 500 | 501 | 504) {\r\n        let codeError = I18N_KEY.ERROR_OCCUR;\r\n        if (code === 501) {\r\n          codeError = I18N_KEY.CDE_CARD_ERROR_501;\r\n        } else if (code === 500) {\r\n          codeError = I18N_KEY.CDE_CARD_ERROR_500;\r\n        } else if (code === 504) {\r\n          codeError = I18N_KEY.CDE_CARD_ERROR_504;\r\n        }\r\n        this.loading = false;\r\n        this.error.emit(codeError);\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.iframe?.removeEventListener('load', this._iframeOnLoadHandler);\r\n        this.unSubscriber.next();\r\n        this.unSubscriber.unsubscribe();\r\n        this._sdk?.unsubscribe();\r\n    }\r\n}\r\n","@if (!status) {\r\n  <div [id]=\"ID_CDE_CONTAINER\"\r\n    [hidden]=\"loading\"\r\n  ></div>\r\n} @else {\r\n  <p class=\"iframe-warning text--warn\"> {{ status | trans}}</p>\r\n}\r\n\r\n@if (loading) {\r\n  <div class=\"trm-skeleton-fields\">\r\n    @for (i of [1,2]; track i) {\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"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-iframe.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  DestroyRef,\r\n  forwardRef,\r\n  inject,\r\n  Injector, Input,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n} from '@angular/forms';\r\nimport { I18N_KEY } from '../../../../../i18n';\r\nimport { LangChangeEvent, TranslateService } from '@ngx-translate/core';\r\nimport { SessionDataSource } from '../../../../../services/session.data-source';\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\nimport { CardSdkService } from './card-sdk.service';\r\nimport { IframeValidatorDirectiveDirective } from './iframe-validator-directive.directive';\r\nimport { insertRemoveTrigger } from \"../../../../../helpers\";\r\nimport { GmSkeletonComponent } from \"@gmmoney/gm-ui-kit\";\r\nimport { CdeTerminalSdk } from './../../../../../models/cde-terminal-sdk';\r\n\r\nconst ID_CDE_CONTAINER = 'cde-container';\r\n\r\n@Component({\r\n  selector: 'app-constructor-field-iframe',\r\n  templateUrl: './constructor-field-iframe.component.html',\r\n  styleUrls: ['./constructor-field-iframe.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  standalone: true,\r\n  animations: [insertRemoveTrigger],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ConstructorFieldIframeComponent),\r\n      multi: true,\r\n    },\r\n    CardSdkService,\r\n  ],\r\n  imports: [TranslateByKeyPipe, GmSkeletonComponent],\r\n  hostDirectives: [\r\n    {\r\n      directive: IframeValidatorDirectiveDirective,\r\n    },\r\n  ],\r\n})\r\nexport class ConstructorFieldIframeComponent\r\n  implements AfterViewInit, ControlValueAccessor\r\n{\r\n  private _translateSrv: TranslateService = inject(TranslateService);\r\n  private _sessionSrv: SessionDataSource = inject(SessionDataSource);\r\n  private _cd: ChangeDetectorRef = inject(ChangeDetectorRef);\r\n  private _control: AbstractControl;\r\n  private _injector: Injector = inject(Injector);\r\n  private _destroyRef: DestroyRef = inject(DestroyRef);\r\n  viewReady = false;\r\n\r\n  @Input() tabIndex: number;\r\n\r\n  private validator: IframeValidatorDirectiveDirective = inject(\r\n    IframeValidatorDirectiveDirective,\r\n  );\r\n\r\n  private _sdk: CdeTerminalSdk;\r\n  private cardSdkSrv: CardSdkService = inject(CardSdkService);\r\n\r\n  private _loading = true;\r\n  status: I18N_KEY;\r\n  readonly I18N_KEY = I18N_KEY;\r\n\r\n  readonly ID_CDE_CONTAINER = ID_CDE_CONTAINER;\r\n  registerOnTouched(fn: any): void {}\r\n  registerOnChange(fn: any): void {}\r\n  writeValue(): void {}\r\n\r\n  get loading(): boolean {\r\n    return this._loading;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this._control = this._injector.get(NgControl).control;\r\n    this.cardSdkSrv\r\n      .createCardTerminalSdk$(\r\n        this._translateSrv.currentLang,\r\n        this.ID_CDE_CONTAINER,\r\n        this.tabIndex\r\n      )\r\n      .pipe(takeUntilDestroyed(this._destroyRef))\r\n      .subscribe({\r\n        next: (sdk: CdeTerminalSdk) => {\r\n          this._sdk = sdk;\r\n          this._destroyRef.onDestroy(() => this._sdk?.unsubscribe());\r\n          this.validator.registerSDK(sdk);\r\n          this._init();\r\n        },\r\n        error: () => {\r\n          this.validator.registerSDK();\r\n          this._updateValueAndValidity();\r\n        },\r\n      });\r\n  }\r\n\r\n  private _updateValueAndValidity(): void {\r\n    this.cardSdkSrv.markAsReady();\r\n    this._control?.updateValueAndValidity({ onlySelf: true });\r\n    this._cd.detectChanges();\r\n    this.refreshHeight();\r\n  }\r\n\r\n  refreshHeight(): void {\r\n    setTimeout(() => {\r\n      this._sdk?.refreshHeight();\r\n      this.viewReady = true;\r\n      this._cd.detectChanges();\r\n    }, 100);\r\n  }\r\n\r\n  private _init(): void {\r\n    this._sdk.onInputPending(() => {\r\n      this._loading = false;\r\n      this._updateValueAndValidity();\r\n    });\r\n\r\n    this._sdk.onInputReady(() => {\r\n      this._updateValueAndValidity();\r\n    });\r\n\r\n    this._sdk.onInputSubmitted(() => {\r\n      this._loading = false;\r\n      this.cardSdkSrv.markAsSubmitted();\r\n      this.status = I18N_KEY.CDE_CARD_ERROR_ALREADY_PAID;\r\n      this._updateValueAndValidity();\r\n    });\r\n\r\n    this._sdk.onTimeout(() => {\r\n      this._updateValueAndValidity();\r\n    });\r\n\r\n    this._sdk.onError(() => {\r\n      this._loading = false;\r\n      this._updateValueAndValidity();\r\n    });\r\n\r\n    this._translateSrv.onLangChange\r\n      .pipe(takeUntilDestroyed(this._destroyRef))\r\n      .subscribe({\r\n        next: (options: LangChangeEvent) => {\r\n          if (!options.lang) {\r\n            return;\r\n          }\r\n          this._sdk.useLang(options.lang);\r\n        },\r\n      });\r\n  }\r\n}\r\n","@if (!status) {\r\n  <div\r\n    class=\"iframe-container\"\r\n    [id]=\"ID_CDE_CONTAINER\"\r\n    [hidden]=\"loading\"\r\n    [class.iframe-container--ready]=\"viewReady\"\r\n  ></div>\r\n} @else if (!loading) {\r\n  <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\r\n}\r\n\r\n@if (loading) {\r\n  <div class=\"trm-skeleton-fields\">\r\n    @for (i of [1,2]; track i) {\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"]}
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
import { Directive, forwardRef, inject } from '@angular/core';
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, } from '@angular/forms';
|
|
3
|
+
import { I18N_KEY } from './../../../../../i18n/i18n-key.enum';
|
|
4
|
+
import { of, Subject } from 'rxjs';
|
|
5
|
+
import { CardSdkService } from './card-sdk.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class IframeValidatorDirectiveDirective {
|
|
8
|
+
constructor() {
|
|
9
|
+
this.cardSdkSrv = inject(CardSdkService);
|
|
10
|
+
this.submitting$ = new Subject();
|
|
11
|
+
this._validationSdkError = false;
|
|
12
|
+
}
|
|
13
|
+
registerSDK(sdk) {
|
|
14
|
+
if (!sdk) {
|
|
15
|
+
this._fatalError = I18N_KEY.ERROR_OCCUR_SDK;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
this._sdk = sdk;
|
|
19
|
+
this.handleSubmitting();
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
handleSubmitting() {
|
|
23
|
+
this._sdk.onInputPending(() => {
|
|
24
|
+
this._validationSdkError = true;
|
|
25
|
+
});
|
|
26
|
+
this._sdk.onError((code) => {
|
|
27
|
+
this._validationSdkError = false;
|
|
28
|
+
let codeError = I18N_KEY.ERROR_OCCUR;
|
|
29
|
+
if (code === 501) {
|
|
30
|
+
codeError = I18N_KEY.CDE_CARD_ERROR_501;
|
|
31
|
+
}
|
|
32
|
+
else if (code === 500) {
|
|
33
|
+
codeError = I18N_KEY.CDE_CARD_ERROR_500;
|
|
34
|
+
}
|
|
35
|
+
else if (code === 504) {
|
|
36
|
+
codeError = I18N_KEY.CDE_CARD_ERROR_504;
|
|
37
|
+
}
|
|
38
|
+
this._fatalError = codeError;
|
|
39
|
+
});
|
|
40
|
+
this._sdk.onInputReady(() => {
|
|
41
|
+
this._validationSdkError = false;
|
|
42
|
+
this.submitting$.next(null);
|
|
43
|
+
});
|
|
44
|
+
this._sdk.onInputSubmitted(() => {
|
|
45
|
+
this._validationSdkError = false;
|
|
46
|
+
this.submitting$.next(null);
|
|
47
|
+
});
|
|
48
|
+
this._sdk.onTimeout(() => {
|
|
49
|
+
this._validationSdkError = false;
|
|
50
|
+
this._fatalError = I18N_KEY.CDE_CARD_ERROR_504;
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
validate(control) {
|
|
54
|
+
if (this._fatalError) {
|
|
55
|
+
return of({ cde_error: this._fatalError });
|
|
56
|
+
}
|
|
57
|
+
if (this._validationSdkError) {
|
|
58
|
+
return of({ cde_validation_error: true });
|
|
59
|
+
}
|
|
60
|
+
if (this.cardSdkSrv.pending) {
|
|
61
|
+
return this.submitting$.asObservable();
|
|
62
|
+
}
|
|
63
|
+
return of(null);
|
|
64
|
+
}
|
|
65
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: IframeValidatorDirectiveDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
66
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: IframeValidatorDirectiveDirective, isStandalone: true, selector: "[appIframeValidatorDirective]", providers: [
|
|
67
|
+
{
|
|
68
|
+
provide: NG_ASYNC_VALIDATORS,
|
|
69
|
+
useExisting: forwardRef(() => IframeValidatorDirectiveDirective),
|
|
70
|
+
multi: true,
|
|
71
|
+
},
|
|
72
|
+
], ngImport: i0 }); }
|
|
73
|
+
}
|
|
74
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: IframeValidatorDirectiveDirective, decorators: [{
|
|
75
|
+
type: Directive,
|
|
76
|
+
args: [{
|
|
77
|
+
selector: '[appIframeValidatorDirective]',
|
|
78
|
+
standalone: true,
|
|
79
|
+
providers: [
|
|
80
|
+
{
|
|
81
|
+
provide: NG_ASYNC_VALIDATORS,
|
|
82
|
+
useExisting: forwardRef(() => IframeValidatorDirectiveDirective),
|
|
83
|
+
multi: true,
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
}]
|
|
87
|
+
}] });
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaWZyYW1lLXZhbGlkYXRvci1kaXJlY3RpdmUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGVybWluYWwtdGVtcGxhdGUvc3JjL2xpYi9hcHAvcGFnZXMvY29tcG9uZW50cy9jb25zdHJ1Y3Rvci1mb3JtL2NvbXBvbmVudHMvY29uc3RydWN0b3ItZmllbGQtaWZyYW1lL2lmcmFtZS12YWxpZGF0b3ItZGlyZWN0aXZlLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDOUQsT0FBTyxFQUdMLG1CQUFtQixHQUVwQixNQUFNLGdCQUFnQixDQUFDO0FBQ3hCLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxxQ0FBcUMsQ0FBQztBQUMvRCxPQUFPLEVBQWMsRUFBRSxFQUFFLE9BQU8sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUMvQyxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBY3BELE1BQU0sT0FBTyxpQ0FBaUM7SUFYOUM7UUFZVSxlQUFVLEdBQW1CLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztRQUdwRCxnQkFBVyxHQUFxQyxJQUFJLE9BQU8sRUFBRSxDQUFDO1FBRzlELHdCQUFtQixHQUFHLEtBQUssQ0FBQztLQXVEckM7SUFyREMsV0FBVyxDQUFDLEdBQW9CO1FBQzlCLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQztZQUNULElBQUksQ0FBQyxXQUFXLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUM5QyxDQUFDO2FBQU0sQ0FBQztZQUNOLElBQUksQ0FBQyxJQUFJLEdBQUcsR0FBRyxDQUFDO1lBQ2hCLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO1FBQzFCLENBQUM7SUFDSCxDQUFDO0lBRU8sZ0JBQWdC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b3J0IHsgRGlyZWN0aXZlLCBmb3J3YXJkUmVmLCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHtcclxuICBBYnN0cmFjdENvbnRyb2wsXHJcbiAgQXN5bmNWYWxpZGF0b3IsXHJcbiAgTkdfQVNZTkNfVkFMSURBVE9SUyxcclxuICBWYWxpZGF0aW9uRXJyb3JzLFxyXG59IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgSTE4Tl9LRVkgfSBmcm9tICcuLy4uLy4uLy4uLy4uLy4uL2kxOG4vaTE4bi1rZXkuZW51bSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIG9mLCBTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IENhcmRTZGtTZXJ2aWNlIH0gZnJvbSAnLi9jYXJkLXNkay5zZXJ2aWNlJztcclxuaW1wb3J0IHsgQ2RlVGVybWluYWxTZGsgfSBmcm9tICcuLy4uLy4uLy4uLy4uLy4uL21vZGVscy9jZGUtdGVybWluYWwtc2RrJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gIHNlbGVjdG9yOiAnW2FwcElmcmFtZVZhbGlkYXRvckRpcmVjdGl2ZV0nLFxyXG4gIHN0YW5kYWxvbmU6IHRydWUsXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX0FTWU5DX1ZBTElEQVRPUlMsXHJcbiAgICAgIHVzZUV4aXN0aW5nOiBmb3J3YXJkUmVmKCgpID0+IElmcmFtZVZhbGlkYXRvckRpcmVjdGl2ZURpcmVjdGl2ZSksXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgSWZyYW1lVmFsaWRhdG9yRGlyZWN0aXZlRGlyZWN0aXZlIGltcGxlbWVudHMgQXN5bmNWYWxpZGF0b3Ige1xyXG4gIHByaXZhdGUgY2FyZFNka1NydjogQ2FyZFNka1NlcnZpY2UgPSBpbmplY3QoQ2FyZFNka1NlcnZpY2UpO1xyXG4gIHByaXZhdGUgX3NkazogQ2RlVGVybWluYWxTZGs7XHJcblxyXG4gIHByaXZhdGUgc3VibWl0dGluZyQ6IFN1YmplY3Q8VmFsaWRhdGlvbkVycm9ycyB8IG51bGw+ID0gbmV3IFN1YmplY3QoKTtcclxuXHJcbiAgcHJpdmF0ZSBfZmF0YWxFcnJvcjogSTE4Tl9LRVk7XHJcbiAgcHJpdmF0ZSBfdmFsaWRhdGlvblNka0Vycm9yID0gZmFsc2U7XHJcblxyXG4gIHJlZ2lzdGVyU0RLKHNkaz86IENkZVRlcm1pbmFsU2RrKTogdm9pZCB7XHJcbiAgICBpZiAoIXNkaykge1xyXG4gICAgICB0aGlzLl9mYXRhbEVycm9yID0gSTE4Tl9LRVkuRVJST1JfT0NDVVJfU0RLO1xyXG4gICAgfSBlbHNlIHtcclxuICAgICAgdGhpcy5fc2RrID0gc2RrO1xyXG4gICAgICB0aGlzLmhhbmRsZVN1Ym1pdHRpbmcoKTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHByaXZhdGUgaGFuZGxlU3VibWl0dGluZygpOiB2b2lkIHtcclxuICAgIHRoaXMuX3Nkay5vbklucHV0UGVuZGluZygoKSA9PiB7XHJcbiAgICAgIHRoaXMuX3ZhbGlkYXRpb25TZGtFcnJvciA9IHRydWU7XHJcbiAgICB9KTtcclxuICAgIHRoaXMuX3Nkay5vbkVycm9yKChjb2RlKSA9PiB7XHJcbiAgICAgIHRoaXMuX3ZhbGlkYXRpb25TZGtFcnJvciA9IGZhbHNlO1xyXG4gICAgICBsZXQgY29kZUVycm9yID0gSTE4Tl9LRVkuRVJST1JfT0NDVVI7XHJcbiAgICAgIGlmIChjb2RlID09PSA1MDEpIHtcclxuICAgICAgICBjb2RlRXJyb3IgPSBJMThOX0tFWS5DREVfQ0FSRF9FUlJPUl81MDE7XHJcbiAgICAgIH0gZWxzZSBpZiAoY29kZSA9PT0gNTAwKSB7XHJcbiAgICAgICAgY29kZUVycm9yID0gSTE4Tl9LRVkuQ0RFX0NBUkRfRVJST1JfNTAwO1xyXG4gICAgICB9IGVsc2UgaWYgKGNvZGUgPT09IDUwNCkge1xyXG4gICAgICAgIGNvZGVFcnJvciA9IEkxOE5fS0VZLkNERV9DQVJEX0VSUk9SXzUwNDtcclxuICAgICAgfVxyXG4gICAgICB0aGlzLl9mYXRhbEVycm9yID0gY29kZUVycm9yO1xyXG4gICAgfSk7XHJcbiAgICB0aGlzLl9zZGsub25JbnB1dFJlYWR5KCgpID0+IHtcclxuICAgICAgdGhpcy5fdmFsaWRhdGlvblNka0Vycm9yID0gZmFsc2U7XHJcbiAgICAgIHRoaXMuc3VibWl0dGluZyQubmV4dChudWxsKTtcclxuICAgIH0pO1xyXG4gICAgdGhpcy5fc2RrLm9uSW5wdXRTdWJtaXR0ZWQoKCkgPT4ge1xyXG4gICAgICB0aGlzLl92YWxpZGF0aW9uU2RrRXJyb3IgPSBmYWxzZTtcclxuICAgICAgdGhpcy5zdWJtaXR0aW5nJC5uZXh0KG51bGwpO1xyXG4gICAgfSk7XHJcbiAgICB0aGlzLl9zZGsub25UaW1lb3V0KCgpID0+IHtcclxuICAgICAgdGhpcy5fdmFsaWRhdGlvblNka0Vycm9yID0gZmFsc2U7XHJcbiAgICAgIHRoaXMuX2ZhdGFsRXJyb3IgPSBJMThOX0tFWS5DREVfQ0FSRF9FUlJPUl81MDQ7XHJcbiAgICB9KTtcclxuICB9XHJcblxyXG4gIHZhbGlkYXRlKFxyXG4gICAgY29udHJvbDogQWJzdHJhY3RDb250cm9sLFxyXG4gICk6IFByb21pc2U8VmFsaWRhdGlvbkVycm9ycyB8IG51bGw+IHwgT2JzZXJ2YWJsZTxWYWxpZGF0aW9uRXJyb3JzIHwgbnVsbD4ge1xyXG4gICAgaWYgKHRoaXMuX2ZhdGFsRXJyb3IpIHtcclxuICAgICAgcmV0dXJuIG9mKHsgY2RlX2Vycm9yOiB0aGlzLl9mYXRhbEVycm9yIH0pO1xyXG4gICAgfVxyXG4gICAgaWYgKHRoaXMuX3ZhbGlkYXRpb25TZGtFcnJvcikge1xyXG4gICAgICByZXR1cm4gb2YoeyBjZGVfdmFsaWRhdGlvbl9lcnJvcjogdHJ1ZSB9KTtcclxuICAgIH1cclxuICAgIGlmICh0aGlzLmNhcmRTZGtTcnYucGVuZGluZykge1xyXG4gICAgICByZXR1cm4gdGhpcy5zdWJtaXR0aW5nJC5hc09ic2VydmFibGUoKTtcclxuICAgIH1cclxuICAgIHJldHVybiBvZihudWxsKTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, inject, Injector, Input } from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import { Subject } from 'rxjs';
|
|
2
|
+
import { FormsModule, NG_VALUE_ACCESSOR, NgControl, ReactiveFormsModule } from '@angular/forms';
|
|
4
3
|
import { insertRemoveTrigger } from './../../../../../helpers/insertRemoveTrigger';
|
|
5
4
|
import { I18N_KEY } from './../../../../../i18n';
|
|
6
5
|
import { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';
|
|
@@ -8,6 +7,15 @@ import { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key
|
|
|
8
7
|
import * as i0 from "@angular/core";
|
|
9
8
|
import * as i1 from "@angular/forms";
|
|
10
9
|
export class ConstructorFieldSelectComponent {
|
|
10
|
+
constructor() {
|
|
11
|
+
this.cd = inject(ChangeDetectorRef);
|
|
12
|
+
this.injector = inject(Injector);
|
|
13
|
+
this.I18N_KEY = I18N_KEY;
|
|
14
|
+
this.onChange = (_value) => {
|
|
15
|
+
};
|
|
16
|
+
this.onTouch = () => {
|
|
17
|
+
};
|
|
18
|
+
}
|
|
11
19
|
get data() {
|
|
12
20
|
if (!this.items) {
|
|
13
21
|
return [];
|
|
@@ -24,17 +32,6 @@ export class ConstructorFieldSelectComponent {
|
|
|
24
32
|
}
|
|
25
33
|
});
|
|
26
34
|
}
|
|
27
|
-
constructor() {
|
|
28
|
-
this.cd = inject(ChangeDetectorRef);
|
|
29
|
-
this.injector = inject(Injector);
|
|
30
|
-
this.unsub = new Subject();
|
|
31
|
-
this.I18N_KEY = I18N_KEY;
|
|
32
|
-
this.onChange = (value) => {
|
|
33
|
-
};
|
|
34
|
-
this.onTouch = () => {
|
|
35
|
-
};
|
|
36
|
-
this.cd.detach();
|
|
37
|
-
}
|
|
38
35
|
registerOnChange(fn) {
|
|
39
36
|
this.onChange = fn;
|
|
40
37
|
}
|
|
@@ -52,27 +49,8 @@ export class ConstructorFieldSelectComponent {
|
|
|
52
49
|
return this.control?.getError('error');
|
|
53
50
|
}
|
|
54
51
|
ngAfterViewInit() {
|
|
55
|
-
this.control = this.injector.get(
|
|
56
|
-
this.cd.reattach();
|
|
52
|
+
this.control = this.injector.get(NgControl).control;
|
|
57
53
|
this.cd.detectChanges();
|
|
58
|
-
this.ngDoCheck();
|
|
59
|
-
}
|
|
60
|
-
ngDoCheck() {
|
|
61
|
-
if (!this.control) {
|
|
62
|
-
return;
|
|
63
|
-
}
|
|
64
|
-
if (this.control.dirty) {
|
|
65
|
-
this.control.markAsDirty();
|
|
66
|
-
this.cd.detectChanges();
|
|
67
|
-
}
|
|
68
|
-
if (this.control.touched) {
|
|
69
|
-
this.control.markAsTouched();
|
|
70
|
-
this.cd.detectChanges();
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
ngOnDestroy() {
|
|
74
|
-
this.unsub.next();
|
|
75
|
-
this.unsub.unsubscribe();
|
|
76
54
|
}
|
|
77
55
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
56
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ConstructorFieldSelectComponent, isStandalone: true, selector: "app-constructor-field-select", inputs: { config: "config", items: "items", tabIndex: "tabIndex" }, providers: [
|
|
@@ -81,7 +59,7 @@ export class ConstructorFieldSelectComponent {
|
|
|
81
59
|
useExisting: forwardRef(() => ConstructorFieldSelectComponent),
|
|
82
60
|
multi: true
|
|
83
61
|
}
|
|
84
|
-
], ngImport: i0, template: "<app-trm-select [data]=\"data\"\r\n
|
|
62
|
+
], ngImport: i0, template: "@if (control) {\r\n <app-trm-select [data]=\"data\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n [label]=\"config.label | trans\"\r\n [name]=\"config.name\"\r\n (search)=\"search($event)\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n [tabIndex]=\"tabIndex\"\r\n class=\"c-field-select trm-form-field\"\r\n ></app-trm-select>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n\r\n}\r\n", styles: [":host{display:block;width:100%}\n"], dependencies: [{ kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
85
63
|
}
|
|
86
64
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldSelectComponent, decorators: [{
|
|
87
65
|
type: Component,
|
|
@@ -91,12 +69,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
|
|
|
91
69
|
useExisting: forwardRef(() => ConstructorFieldSelectComponent),
|
|
92
70
|
multi: true
|
|
93
71
|
}
|
|
94
|
-
], standalone: true, imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "<app-trm-select [data]=\"data\"\r\n
|
|
95
|
-
}],
|
|
72
|
+
], standalone: true, imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (control) {\r\n <app-trm-select [data]=\"data\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n [label]=\"config.label | trans\"\r\n [name]=\"config.name\"\r\n (search)=\"search($event)\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n [tabIndex]=\"tabIndex\"\r\n class=\"c-field-select trm-form-field\"\r\n ></app-trm-select>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n\r\n}\r\n", styles: [":host{display:block;width:100%}\n"] }]
|
|
73
|
+
}], propDecorators: { config: [{
|
|
96
74
|
type: Input
|
|
97
75
|
}], items: [{
|
|
98
76
|
type: Input
|
|
99
77
|
}], tabIndex: [{
|
|
100
78
|
type: Input
|
|
101
79
|
}] } });
|
|
102
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-select.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  DoCheck,\r\n  forwardRef,\r\n  inject,\r\n  Injector,\r\n  Input,\r\n  OnDestroy\r\n} from '@angular/core';\r\nimport { PaymentField, PaymentFieldOptionsItem } from '../../models';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormControlName,\r\n  FormsModule,\r\n  NG_VALUE_ACCESSOR,\r\n  ReactiveFormsModule\r\n} from '@angular/forms';\r\nimport { Subject } from 'rxjs';\r\nimport { insertRemoveTrigger } from './../../../../../helpers/insertRemoveTrigger';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';\r\n\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\n\r\n@Component({\r\n    selector: 'app-constructor-field-select',\r\n    templateUrl: './constructor-field-select.component.html',\r\n    styleUrls: ['./constructor-field-select.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    animations: [insertRemoveTrigger],\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ConstructorFieldSelectComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    standalone: true,\r\n    imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe]\r\n})\r\nexport class ConstructorFieldSelectComponent implements ControlValueAccessor, OnDestroy, AfterViewInit, DoCheck {\r\n    private cd = inject(ChangeDetectorRef);\r\n    private injector = inject(Injector);\r\n\r\n    private unsub: Subject<void> = new Subject<void>();\r\n    @Input() config: PaymentField;\r\n    @Input() items: PaymentFieldOptionsItem[];\r\n    @Input() tabIndex: number;\r\n    searchString: string;\r\n    I18N_KEY = I18N_KEY;\r\n\r\n    onChange = (value) => {\r\n    };\r\n    onTouch = () => {\r\n    };\r\n    control;\r\n\r\n    get data() {\r\n        if (!this.items) {\r\n            return [];\r\n        }\r\n        return this.items\r\n            .filter((option: PaymentFieldOptionsItem) => {\r\n                if (!this.searchString) {\r\n                    return true;\r\n                } else {\r\n                    const title: string = option.name;\r\n                    return title.toLowerCase()\r\n                        .split(' ').some(\r\n                            ts => this.searchString.toLowerCase().split(' ').some(s => ts.includes(s))\r\n                        );\r\n                }\r\n            })\r\n    }\r\n\r\n    constructor() {\r\n        this.cd.detach();\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    search(searchString) {\r\n        this.searchString = searchString;\r\n        this.cd.markForCheck();\r\n    }\r\n\r\n    writeValue(value: any) {\r\n        this.cd.markForCheck();\r\n    }\r\n\r\n    get apiError(): string {\r\n        return this.control?.getError('error');\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this.control = this.injector.get(FormControlName).control;\r\n        this.cd.reattach();\r\n        this.cd.detectChanges();\r\n        this.ngDoCheck();\r\n    }\r\n\r\n    ngDoCheck() {\r\n        if (!this.control) {\r\n            return\r\n        }\r\n\r\n        if (this.control.dirty) {\r\n            this.control.markAsDirty();\r\n            this.cd.detectChanges();\r\n        }\r\n        if (this.control.touched) {\r\n            this.control.markAsTouched();\r\n            this.cd.detectChanges();\r\n        }\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.unsub.next();\r\n        this.unsub.unsubscribe();\r\n    }\r\n}\r\n","<app-trm-select [data]=\"data\"\r\n  [placeholder]=\"config.placeholder | trans\"\r\n  [label]=\"config.label | trans\"\r\n  [name]=\"config.name\"\r\n  (search)=\"search($event)\"\r\n  (open)=\"onTouch()\"\r\n  [formControl]=\"control\"\r\n  [tabIndex] = \"tabIndex\"\r\n  class=\"c-field-select trm-form-field\"\r\n></app-trm-select>\r\n@if (control.hasError('required') && control.touched && control.dirty) {\r\n  <div class=\"trm-error\"\r\n    @insertRemove\r\n    >\r\n    {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n  </div>\r\n}\r\n@if (control.hasError('error') && control.touched && control.dirty) {\r\n  <div class=\"trm-error\"\r\n    @insertRemove\r\n    >\r\n    {{ apiError | trans }}\r\n  </div>\r\n}\r\n\r\n@if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n  <div class=\"trm-error\"\r\n    @insertRemove\r\n    >\r\n    {{ control.getError('custom_error') | trans }}\r\n  </div>\r\n}\r\n"]}
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-select.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  forwardRef,\r\n  inject,\r\n  Injector,\r\n  Input\r\n} from '@angular/core';\r\nimport { PaymentField, PaymentFieldOptionsItem } from '../../models';\r\nimport {\r\n  AbstractControl,\r\n  ControlValueAccessor,\r\n  FormsModule,\r\n  NG_VALUE_ACCESSOR,\r\n  NgControl,\r\n  ReactiveFormsModule\r\n} from '@angular/forms';\r\nimport { insertRemoveTrigger } from './../../../../../helpers/insertRemoveTrigger';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';\r\n\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\n\r\n@Component({\r\n  selector: 'app-constructor-field-select',\r\n  templateUrl: './constructor-field-select.component.html',\r\n  styleUrls: ['./constructor-field-select.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  animations: [insertRemoveTrigger],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ConstructorFieldSelectComponent),\r\n      multi: true\r\n    }\r\n  ],\r\n  standalone: true,\r\n  imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe]\r\n})\r\nexport class ConstructorFieldSelectComponent implements ControlValueAccessor, AfterViewInit {\r\n  private cd = inject(ChangeDetectorRef);\r\n  private injector = inject(Injector);\r\n  @Input() config: PaymentField;\r\n  @Input() items: PaymentFieldOptionsItem[];\r\n  @Input() tabIndex: number;\r\n  searchString: string;\r\n  I18N_KEY = I18N_KEY;\r\n\r\n  onChange = (_value: any) => {\r\n  };\r\n  onTouch = () => {\r\n  };\r\n  control: AbstractControl;\r\n\r\n  get data() {\r\n    if (!this.items) {\r\n      return [];\r\n    }\r\n    return this.items\r\n      .filter((option: PaymentFieldOptionsItem) => {\r\n        if (!this.searchString) {\r\n          return true;\r\n        } else {\r\n          const title: string = option.name;\r\n          return title.toLowerCase()\r\n            .split(' ').some(\r\n              ts => this.searchString.toLowerCase().split(' ').some(s => ts.includes(s))\r\n            );\r\n        }\r\n      })\r\n  }\r\n\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  search(searchString: string) {\r\n    this.searchString = searchString;\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  writeValue(value: any) {\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  get apiError(): string {\r\n    return this.control?.getError('error');\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.control = this.injector.get(NgControl).control;\r\n    this.cd.detectChanges();\r\n  }\r\n}\r\n","@if (control) {\r\n  <app-trm-select [data]=\"data\"\r\n                  [placeholder]=\"config.placeholder | trans\"\r\n                  [label]=\"config.label | trans\"\r\n                  [name]=\"config.name\"\r\n                  (search)=\"search($event)\"\r\n                  (open)=\"onTouch()\"\r\n                  [formControl]=\"control\"\r\n                  [tabIndex]=\"tabIndex\"\r\n                  class=\"c-field-select trm-form-field\"\r\n  ></app-trm-select>\r\n  @if (control.hasError('required') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('error') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ apiError | trans }}\r\n    </div>\r\n  }\r\n\r\n  @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ control.getError('custom_error') | trans }}\r\n    </div>\r\n  }\r\n\r\n}\r\n"]}
|