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.
Files changed (68) hide show
  1. package/esm2022/lib/app/i18n/i18n-key.enum.mjs +2 -1
  2. package/esm2022/lib/app/i18n/keys.mjs +3 -2
  3. package/esm2022/lib/app/models/constants.mjs +4 -2
  4. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.mjs +24 -38
  5. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.mjs +41 -0
  6. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.mjs +99 -117
  7. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.mjs +88 -0
  8. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.mjs +15 -37
  9. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.mjs +10 -4
  10. package/esm2022/lib/app/pages/components/constructor-form/components/index.mjs +3 -1
  11. package/esm2022/lib/app/pages/components/constructor-form/components/method-amount-hint/method-amount-hint.component.mjs +11 -7
  12. package/esm2022/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.mjs +20 -24
  13. package/esm2022/lib/app/pages/components/constructor-form/constructor-form.component.mjs +90 -64
  14. package/esm2022/lib/app/pages/components/constructor-form/models/field-template.mjs +2 -1
  15. package/esm2022/lib/app/pages/components/constructor-form/models/index.mjs +1 -2
  16. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field-options.mjs +1 -1
  17. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field.mjs +1 -1
  18. package/esm2022/lib/app/pages/components/constructor-form/services/constructor-form.service.mjs +40 -25
  19. package/esm2022/lib/app/pages/components/terminal-layout/terminal-layout.component.mjs +11 -9
  20. package/esm2022/lib/app/pages/directives/fee-template.directive.mjs +17 -0
  21. package/esm2022/lib/app/pages/directives/index.mjs +2 -1
  22. package/esm2022/lib/app/services/api-errors.service.mjs +16 -34
  23. package/esm2022/lib/app/services/csrf.resolver.mjs +6 -18
  24. package/esm2022/lib/app/services/error.interceptior.mjs +2 -2
  25. package/esm2022/lib/app/services/local-storage.mjs +70 -0
  26. package/esm2022/lib/app/services/script-loader.mjs +4 -7
  27. package/esm2022/lib/app/services/session.data-source.mjs +12 -11
  28. package/esm2022/lib/app/services/translation/translate-lang-storage.service.mjs +95 -79
  29. package/esm2022/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.mjs +10 -8
  30. package/esm2022/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.mjs +6 -6
  31. package/esm2022/lib/app/shared/components/trm-select/trm-select.component.mjs +1 -1
  32. package/esm2022/lib/app/terminal-tpl.component.mjs +13 -16
  33. package/esm2022/lib/app/terminal.module.mjs +43 -75
  34. package/fesm2022/trm-tmpl.mjs +936 -793
  35. package/fesm2022/trm-tmpl.mjs.map +1 -1
  36. package/lib/app/i18n/i18n-key.enum.d.ts +1 -0
  37. package/lib/app/models/constants.d.ts +3 -1
  38. package/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.d.ts +7 -10
  39. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.d.ts +18 -0
  40. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.d.ts +24 -27
  41. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.d.ts +16 -0
  42. package/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.d.ts +6 -10
  43. package/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.d.ts +3 -3
  44. package/lib/app/pages/components/constructor-form/components/index.d.ts +2 -0
  45. package/lib/app/pages/components/constructor-form/components/method-amount-hint/method-amount-hint.component.d.ts +3 -0
  46. package/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.d.ts +4 -6
  47. package/lib/app/pages/components/constructor-form/constructor-form.component.d.ts +6 -9
  48. package/lib/app/pages/components/constructor-form/models/index.d.ts +0 -1
  49. package/lib/app/pages/components/constructor-form/models/payment-field-options.d.ts +1 -1
  50. package/lib/app/pages/components/constructor-form/models/payment-field.d.ts +1 -1
  51. package/lib/app/pages/components/constructor-form/services/constructor-form.service.d.ts +8 -5
  52. package/lib/app/pages/components/terminal-layout/terminal-layout.component.d.ts +1 -0
  53. package/lib/app/pages/directives/fee-template.directive.d.ts +7 -0
  54. package/lib/app/pages/directives/index.d.ts +1 -0
  55. package/lib/app/services/api-errors.service.d.ts +4 -10
  56. package/lib/app/services/csrf.resolver.d.ts +1 -4
  57. package/lib/app/services/local-storage.d.ts +24 -0
  58. package/lib/app/services/script-loader.d.ts +1 -2
  59. package/lib/app/services/session.data-source.d.ts +1 -1
  60. package/lib/app/services/translation/translate-lang-storage.service.d.ts +22 -23
  61. package/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.d.ts +4 -34
  62. package/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.d.ts +1 -2
  63. package/lib/app/shared/components/trm-select/trm-select.component.d.ts +1 -2
  64. package/lib/app/terminal-tpl.component.d.ts +2 -1
  65. package/lib/app/terminal.module.d.ts +26 -4
  66. package/package.json +1 -1
  67. package/esm2022/lib/app/pages/components/constructor-form/models/constants.mjs +0 -4
  68. package/lib/app/pages/components/constructor-form/models/constants.d.ts +0 -3
@@ -1,141 +1,123 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, Input, Output } from '@angular/core';
2
- import { I18N_KEY } from './../../../../../i18n';
3
- import { TranslateService } from "@ngx-translate/core";
4
- import { takeUntil } from "rxjs/operators";
5
- import { Subject } from "rxjs";
6
- import { SessionDataSource } from "../../../../../services/session.data-source";
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';
8
6
  import { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';
7
+ import { CardSdkService } from './card-sdk.service';
8
+ import { IframeValidatorDirectiveDirective } from './iframe-validator-directive.directive';
9
+ import { insertRemoveTrigger } from '../../../../../helpers';
9
10
  import { GmSkeletonComponent } from '@gmmoney/gm-ui-kit';
10
11
  import * as i0 from "@angular/core";
12
+ import * as i1 from "./iframe-validator-directive.directive";
13
+ const ID_CDE_CONTAINER = 'cde-container';
11
14
  export class ConstructorFieldIframeComponent {
12
- get finished() {
13
- return this._finished;
14
- }
15
15
  constructor() {
16
- this.translateSrv = inject(TranslateService);
17
- this.sessionSrv = inject(SessionDataSource);
18
- this.cd = inject(ChangeDetectorRef);
19
- this.scriptLoaderSrv = inject(ScriptLoader);
20
- this.ID_CDE_CONTAINER = 'cde-container';
21
- this.unSubscriber = new Subject();
22
- this.loading = true;
16
+ this._translateSrv = inject(TranslateService);
17
+ this._cd = inject(ChangeDetectorRef);
18
+ this._injector = inject(Injector);
19
+ this._destroyRef = inject(DestroyRef);
20
+ this.viewReady = false;
21
+ this.validator = inject(IframeValidatorDirectiveDirective);
22
+ this.cardSdkSrv = inject(CardSdkService);
23
+ this._loading = true;
23
24
  this.I18N_KEY = I18N_KEY;
24
- this.error = new EventEmitter();
25
- this.paid = new EventEmitter();
26
- this.ready = new EventEmitter();
27
- this._iframeOnLoadHandler = () => {
28
- this.loading = false;
29
- this.cd.detectChanges();
30
- };
31
- this._ready = false;
32
- this._finished = false;
33
- this.submitted = false;
25
+ this.ID_CDE_CONTAINER = ID_CDE_CONTAINER;
26
+ }
27
+ registerOnTouched(fn) { }
28
+ registerOnChange(fn) { }
29
+ writeValue() { }
30
+ get loading() {
31
+ return this._loading;
34
32
  }
35
33
  ngAfterViewInit() {
36
- this.scriptLoaderSrv
37
- .fetchScript('cde_sdk')
38
- .then(() => this._init(), () => this._onError());
34
+ this._control = this._injector.get(NgControl).control;
35
+ this.cardSdkSrv
36
+ .createCardTerminalSdk$(this._translateSrv.currentLang, this.ID_CDE_CONTAINER, this.tabIndex)
37
+ .pipe(takeUntilDestroyed(this._destroyRef))
38
+ .subscribe({
39
+ next: (sdk) => {
40
+ this._sdk = sdk;
41
+ this._destroyRef.onDestroy(() => this._sdk?.unsubscribe());
42
+ this.validator.registerSDK(sdk);
43
+ this._init();
44
+ },
45
+ error: () => {
46
+ this.validator.registerSDK();
47
+ this._updateValueAndValidity();
48
+ },
49
+ });
39
50
  }
40
- get lang() {
41
- return this.translateSrv.currentLang;
51
+ _updateValueAndValidity() {
52
+ this.cardSdkSrv.markAsReady();
53
+ this._control?.updateValueAndValidity({ onlySelf: true });
54
+ this._cd.detectChanges();
55
+ this.refreshHeight();
42
56
  }
43
- get iframe() {
44
- return this._sdk?.iframe;
57
+ refreshHeight() {
58
+ setTimeout(() => {
59
+ this._sdk?.refreshHeight();
60
+ this.viewReady = true;
61
+ this._cd.detectChanges();
62
+ }, 100);
45
63
  }
46
64
  _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
65
  this._sdk.onInputPending(() => {
57
- setTimeout(() => {
58
- this._sdk.refreshHeight();
59
- });
60
- this._ready = false;
66
+ this._loading = false;
67
+ this._updateValueAndValidity();
61
68
  });
62
- this._sdk.onInputReady(() => this._ready = true);
63
- this._sdk
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();
69
+ this._sdk.onInputReady(() => {
70
+ this._updateValueAndValidity();
74
71
  });
75
- this._sdk
76
- .onTimeout(() => this.error.emit(I18N_KEY.CDE_CARD_ERROR_504));
77
- this.translateSrv
78
- .onLangChange
79
- .pipe(takeUntil(this.unSubscriber))
80
- .subscribe((options) => {
81
- if (!options.lang) {
82
- return;
83
- }
84
- this._sdk.useLang(options.lang);
72
+ this._sdk.onInputSubmitted(() => {
73
+ this._loading = false;
74
+ this.cardSdkSrv.markAsSubmitted();
75
+ this.status = I18N_KEY.CDE_CARD_ERROR_ALREADY_PAID;
76
+ this._updateValueAndValidity();
85
77
  });
86
- }
87
- submit() {
88
- this.submitted = true;
89
- const subscriptions = [];
90
- return new Promise((resolve) => {
91
- if (!this._ready) {
92
- resolve(false);
93
- }
94
- else {
95
- subscriptions.push(this._sdk.onInputPending(() => resolve(false)));
96
- subscriptions.push(this._sdk.onError(() => resolve(false)));
97
- subscriptions.push(this._sdk.onInputSubmitted(() => resolve(true)));
98
- }
99
- this._sdk.submit();
100
- })
101
- .then((result) => {
102
- subscriptions.map(s => s.unsubscribe());
103
- return result;
78
+ this._sdk.onTimeout(() => {
79
+ this._updateValueAndValidity();
80
+ });
81
+ this._sdk.onError(() => {
82
+ this._loading = false;
83
+ this._updateValueAndValidity();
84
+ });
85
+ this._translateSrv.onLangChange
86
+ .pipe(takeUntilDestroyed(this._destroyRef))
87
+ .subscribe({
88
+ next: (options) => {
89
+ if (!options.lang) {
90
+ return;
91
+ }
92
+ this._sdk.useLang(options.lang);
93
+ },
104
94
  });
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
95
  }
126
96
  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" }, outputs: { error: "error", paid: "paid", ready: "ready" }, ngImport: i0, template: "@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", styles: [".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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
97
+ 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: [
98
+ {
99
+ provide: NG_VALUE_ACCESSOR,
100
+ useExisting: forwardRef(() => ConstructorFieldIframeComponent),
101
+ multi: true,
102
+ },
103
+ CardSdkService,
104
+ ], 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
105
  }
129
106
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldIframeComponent, decorators: [{
130
107
  type: Component,
131
- args: [{ selector: 'app-constructor-field-iframe', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [TranslateByKeyPipe, GmSkeletonComponent], template: "@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", styles: [".iframe-warning{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}\n"] }]
132
- }], ctorParameters: () => [], propDecorators: { error: [{
133
- type: Output
134
- }], paid: [{
135
- type: Output
136
- }], ready: [{
137
- type: Output
138
- }], tabIndex: [{
108
+ args: [{ selector: 'app-constructor-field-iframe', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, animations: [insertRemoveTrigger], providers: [
109
+ {
110
+ provide: NG_VALUE_ACCESSOR,
111
+ useExisting: forwardRef(() => ConstructorFieldIframeComponent),
112
+ multi: true,
113
+ },
114
+ CardSdkService,
115
+ ], imports: [TranslateByKeyPipe, GmSkeletonComponent], hostDirectives: [
116
+ {
117
+ directive: IframeValidatorDirectiveDirective,
118
+ },
119
+ ], 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"] }]
120
+ }], propDecorators: { tabIndex: [{
139
121
  type: Input
140
122
  }] } });
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":"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","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"]}
123
+ //# 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,\r\n  Input,\r\n} from '@angular/core';\r\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\r\nimport { AbstractControl, ControlValueAccessor, NG_VALUE_ACCESSOR, NgControl, } from '@angular/forms';\r\nimport { I18N_KEY } from '../../../../../i18n';\r\nimport { LangChangeEvent, TranslateService } from '@ngx-translate/core';\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 _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 { FormControlName, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
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(FormControlName).control;
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 [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", 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 }); }
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 [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", styles: [":host{display:block;width:100%}\n"] }]
95
- }], ctorParameters: () => [], propDecorators: { config: [{
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"]}