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.
Files changed (57) 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 +102 -118
  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/ps-select/ps-select.component.mjs +20 -24
  12. package/esm2022/lib/app/pages/components/constructor-form/constructor-form.component.mjs +89 -66
  13. package/esm2022/lib/app/pages/components/constructor-form/models/field-template.mjs +2 -1
  14. package/esm2022/lib/app/pages/components/constructor-form/models/index.mjs +1 -2
  15. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field.mjs +1 -1
  16. package/esm2022/lib/app/pages/components/constructor-form/services/constructor-form.service.mjs +39 -24
  17. package/esm2022/lib/app/pages/components/terminal-layout/terminal-layout.component.mjs +11 -9
  18. package/esm2022/lib/app/services/api-errors.service.mjs +16 -34
  19. package/esm2022/lib/app/services/csrf.resolver.mjs +6 -18
  20. package/esm2022/lib/app/services/error.interceptior.mjs +2 -2
  21. package/esm2022/lib/app/services/local-storage.mjs +70 -0
  22. package/esm2022/lib/app/services/script-loader.mjs +4 -7
  23. package/esm2022/lib/app/services/session.data-source.mjs +8 -8
  24. package/esm2022/lib/app/services/translation/translate-lang-storage.service.mjs +95 -79
  25. package/esm2022/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.mjs +10 -8
  26. package/esm2022/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.mjs +6 -6
  27. package/esm2022/lib/app/shared/components/trm-select/trm-select.component.mjs +1 -1
  28. package/esm2022/lib/app/terminal-tpl.component.mjs +5 -12
  29. package/fesm2022/trm-tmpl.mjs +738 -587
  30. package/fesm2022/trm-tmpl.mjs.map +1 -1
  31. package/lib/app/i18n/i18n-key.enum.d.ts +1 -0
  32. package/lib/app/models/constants.d.ts +3 -1
  33. package/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.d.ts +7 -10
  34. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.d.ts +18 -0
  35. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.d.ts +25 -27
  36. package/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.d.ts +16 -0
  37. package/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.d.ts +6 -10
  38. package/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.d.ts +3 -3
  39. package/lib/app/pages/components/constructor-form/components/index.d.ts +2 -0
  40. package/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.d.ts +4 -6
  41. package/lib/app/pages/components/constructor-form/constructor-form.component.d.ts +5 -8
  42. package/lib/app/pages/components/constructor-form/models/index.d.ts +0 -1
  43. package/lib/app/pages/components/constructor-form/models/payment-field.d.ts +1 -1
  44. package/lib/app/pages/components/constructor-form/services/constructor-form.service.d.ts +8 -5
  45. package/lib/app/pages/components/terminal-layout/terminal-layout.component.d.ts +1 -0
  46. package/lib/app/services/api-errors.service.d.ts +4 -10
  47. package/lib/app/services/csrf.resolver.d.ts +1 -4
  48. package/lib/app/services/local-storage.d.ts +24 -0
  49. package/lib/app/services/script-loader.d.ts +1 -2
  50. package/lib/app/services/session.data-source.d.ts +1 -1
  51. package/lib/app/services/translation/translate-lang-storage.service.d.ts +22 -23
  52. package/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.d.ts +4 -34
  53. package/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.d.ts +1 -2
  54. package/lib/app/shared/components/trm-select/trm-select.component.d.ts +1 -2
  55. package/package.json +1 -1
  56. package/esm2022/lib/app/pages/components/constructor-form/models/constants.mjs +0 -4
  57. package/lib/app/pages/components/constructor-form/models/constants.d.ts +0 -3
@@ -32,7 +32,7 @@ export class ConstructorFieldTextComponent {
32
32
  this.dropSpecialCharacters = true;
33
33
  this.I18N_KEY = I18N_KEY;
34
34
  this.maskedValueChange = new EventEmitter();
35
- this.onChange = (value) => {
35
+ this.onChange = (_value) => {
36
36
  };
37
37
  this.onTouch = () => {
38
38
  };
@@ -52,7 +52,9 @@ export class ConstructorFieldTextComponent {
52
52
  this.control?.markAsUntouched();
53
53
  e.preventDefault();
54
54
  e.stopPropagation();
55
- target.value = this.maskPipe.transform(target.value, this.mask, { patterns: this.maskPatterns }).replace(/^-|-$/, '');
55
+ target.value = this.maskPipe
56
+ .transform(target.value, this.mask, { patterns: this.maskPatterns })
57
+ .replace(/^-|-$/, '');
56
58
  setTimeout(() => {
57
59
  this.control?.updateValueAndValidity();
58
60
  if (selectionStart === selectionEnd && e.inputType !== 'deleteContentBackward') {
@@ -71,7 +73,7 @@ export class ConstructorFieldTextComponent {
71
73
  return;
72
74
  }
73
75
  const value = t.value;
74
- let content = e.clipboardData.getData('text');
76
+ let content = e.clipboardData?.getData('text') || '';
75
77
  let selectionStart = removeSpecSymbols(t.value.slice(0, t.selectionStart)).length + removeSpecSymbols(content).length;
76
78
  if (value) {
77
79
  const arr = Array.from(value);
@@ -92,6 +94,10 @@ export class ConstructorFieldTextComponent {
92
94
  return;
93
95
  }
94
96
  const target = e.target;
97
+ if (this.type === PaymentFieldTypeEnum.Email) {
98
+ this._emitMaskedValueChanges(target);
99
+ return;
100
+ }
95
101
  const value = this.control?.value;
96
102
  let selectionStart = removeSpecSymbols(target.value.slice(0, target.selectionStart)).length;
97
103
  const mask = this.maskSrv.getMaskByValue(this.config.mask, value);
@@ -187,4 +193,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
187
193
  type: ViewChild,
188
194
  args: [NgxMaskDirective]
189
195
  }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-text.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.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  EventEmitter,\r\n  forwardRef,\r\n  inject,\r\n  Injector,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { FORMAT_DATE, PaymentField, PaymentFieldTypeEnum } 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 { Subject } from 'rxjs';\r\nimport { MatDatepicker, MatDatepickerInput } from '@angular/material/datepicker';\r\nimport momentjs from 'moment-timezone';\r\nimport { insertRemoveTrigger } from './../../../../../helpers/insertRemoveTrigger';\r\nimport { INITIAL_PHONE_MASK, MaskResolver } from './../../../../../helpers/mask-resolver';\r\nimport { NgxMaskDirective, NgxMaskPipe } from 'ngx-mask';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { removeSpecSymbols } from '../../../../../helpers/phone-codes';\r\nimport { InputMaskCorrector } from '../../../../directives/input-mask-corrector.directive';\r\nimport { TabIndexFocusDirective } from '../../../../directives/tab-index-focus.directive';\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\n\r\n@Component({\r\n    selector: 'app-constructor-field-text',\r\n    templateUrl: './constructor-field-text.component.html',\r\n    styleUrls: ['./constructor-field-text.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(() => ConstructorFieldTextComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    standalone: true,\r\n    imports: [FormsModule, NgxMaskDirective, InputMaskCorrector, ReactiveFormsModule, TabIndexFocusDirective, MatDatepickerInput, TranslateByKeyPipe]\r\n})\r\nexport class ConstructorFieldTextComponent implements ControlValueAccessor, OnInit, OnDestroy, AfterViewInit {\r\n    private cd = inject(ChangeDetectorRef);\r\n    private maskSrv = inject(MaskResolver);\r\n    private injector = inject(Injector);\r\n    private maskPipe = inject(NgxMaskPipe);\r\n\r\n    private unsub: Subject<void> = new Subject<void>();\r\n    private _type = 'text';\r\n\r\n    get disabled() {\r\n        return this.config.readonly || false;\r\n    };\r\n    readonly FORMAT_DATE = FORMAT_DATE;\r\n    mask: string;\r\n    dropSpecialCharacters = true;\r\n    I18N_KEY = I18N_KEY;\r\n\r\n    @Input() config: PaymentField;\r\n    get inputmode(): \"text\" | \"tel\" | \"numeric\" | \"email\" | \"url\" | \"none\" {\r\n      return this.config.inputMode || 'text';\r\n    }\r\n    @Input() matDatepicker: MatDatepicker<momentjs.Moment>;\r\n    @Input() tabIndex: number;\r\n    @Output() maskedValueChange: EventEmitter<string> = new EventEmitter();\r\n    control: AbstractControl;\r\n    @ViewChild(NgxMaskDirective) dir: NgxMaskDirective;\r\n    maskPatterns;\r\n    specialCharacters: string[];\r\n    onChange = (value) => {\r\n    };\r\n    onTouch = () => {\r\n    };\r\n\r\n    constructor() {}\r\n\r\n    get type() {\r\n        if (this.config.type === PaymentFieldTypeEnum.Email) {\r\n            return 'email';\r\n        }\r\n        return this._type;\r\n    }\r\n    get name() {\r\n        return this.config.name;\r\n    }\r\n\r\n    public onDateInput(e: InputEvent) {\r\n        const target: HTMLInputElement = e.target as HTMLInputElement;\r\n        let {selectionStart, selectionEnd} = target;\r\n        this.control?.markAsUntouched();\r\n        e.preventDefault();\r\n        e.stopPropagation();\r\n        target.value = this.maskPipe.transform(target.value, this.mask, {patterns: this.maskPatterns}).replace(/^-|-$/,'');\r\n\r\n        setTimeout(() => {\r\n            this.control?.updateValueAndValidity();\r\n\r\n            if (selectionStart === selectionEnd && e.inputType !== 'deleteContentBackward') {\r\n                while (this.specialCharacters.includes(target.value[selectionEnd - 1])) {\r\n                    selectionEnd += 1;\r\n                    selectionStart += 1;\r\n                }\r\n            }\r\n            target.setSelectionRange(selectionStart, selectionEnd);\r\n        });\r\n    }\r\n\r\n    public onPaste(e: ClipboardEvent) {\r\n        const t = e.target as HTMLInputElement;\r\n        if (this.type === PaymentFieldTypeEnum.Email) {\r\n          this._emitMaskedValueChanges(t);\r\n          return;\r\n        }\r\n        const value = t.value;\r\n        let content = e.clipboardData.getData('text');\r\n        let selectionStart = removeSpecSymbols(t.value.slice(0, t.selectionStart)).length + removeSpecSymbols(content).length;\r\n        if (value) {\r\n            const arr = Array.from(value);\r\n            arr.splice(t.selectionStart, t.selectionEnd - t.selectionStart, ...Array.from(content));\r\n            content = removeSpecSymbols(arr.join(''));\r\n        }\r\n        this.mask = this.maskSrv.getMaskByValue(this.config.mask, content);\r\n        this.cd.detectChanges();\r\n        this.control?.setValue(content);\r\n        this.cd.detectChanges();\r\n        e.preventDefault();\r\n        this._emitMaskedValueChanges(t, selectionStart);\r\n    }\r\n\r\n    public onInput(e: InputEvent) {\r\n        this.control?.markAsUntouched();\r\n        this.cd.markForCheck();\r\n        if (this.matDatepicker) {\r\n            return;\r\n        }\r\n        const target = e.target as HTMLInputElement;\r\n        const value: string = this.control?.value;\r\n        let selectionStart = removeSpecSymbols(target.value.slice(0, target.selectionStart)).length;\r\n        const mask = this.maskSrv.getMaskByValue(this.config.mask, value);\r\n        if (!mask || mask === INITIAL_PHONE_MASK) {\r\n            return;\r\n        }\r\n        this.mask = mask;\r\n\r\n        this.cd.detectChanges();\r\n        this._emitMaskedValueChanges(target, selectionStart);\r\n    }\r\n\r\n    private _emitMaskedValueChanges(target, positionInUnmaskedValue?) {\r\n        setTimeout(() => {\r\n            this.control?.updateValueAndValidity();\r\n            if (this.mask) {\r\n                this.maskedValueChange.emit(target.value);\r\n            }\r\n            this._setSelection(target, positionInUnmaskedValue);\r\n        });\r\n    }\r\n\r\n    private _setSelection(target: HTMLInputElement, positionInUnmaskedValue?) {\r\n        if (this.type === PaymentFieldTypeEnum.Email) {\r\n          return;\r\n        }\r\n        let positionMaskedValue = 0;\r\n        let i = 0;\r\n        while (positionInUnmaskedValue > i && target.value.length > positionMaskedValue) {\r\n            if (/\\d/.test(target.value[positionMaskedValue])) {\r\n                i++;\r\n            }\r\n            positionMaskedValue++;\r\n        }\r\n        target.setSelectionRange(positionMaskedValue, positionMaskedValue);\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    get apiError(): string {\r\n        return this.control?.getError('error');\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    writeValue(value) {\r\n        if (value) {\r\n            this.mask = this.maskSrv.getMaskByValue(this.config.mask, value);\r\n        }\r\n        this.cd.markForCheck();\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.mask = this.maskSrv.getMaskByValue(this.config.mask);\r\n        if (this.config.maskValidation !== true) {\r\n            this.config.maskValidation = false;\r\n        }\r\n        this.maskPatterns = this.maskSrv.getPatterns(this.config);\r\n        this.specialCharacters = [...this.maskSrv.getSpecialCharacters(this.config)];\r\n        this.dropSpecialCharacters = this.config.dropSpecialCharacters !== false;\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.unsub.next();\r\n        this.unsub.unsubscribe();\r\n    }\r\n}\r\n","@if (control) {\r\n  <label class=\"trm-label\"\r\n         [for]=\"config.name\"\r\n  > {{ config.label | trans }} </label>\r\n  <div class=\"input-wrapper trm-form-field-wrapper c-text\"\r\n       [class.c-text--disabled]=\"disabled\"\r\n       [class.c-text--uppercase]=\"config.uppercase\">\r\n    @if (!matDatepicker) {\r\n      <input\r\n        class=\"trm-form-field trm-input\"\r\n        [class.trm-form-field--disabled]=\"disabled\"\r\n        [placeholder]=\"config.placeholder | trans\"\r\n        (blur)=\"onTouch()\"\r\n        [formControl]=\"control\"\r\n        (input)=\"onInput($event)\"\r\n        (paste)=\"onPaste($event)\"\r\n        [type]=\"type\"\r\n        [name]=\"name\"\r\n        [id]=\"name\"\r\n        [mask]=\"mask\"\r\n        [attr.inputmode]=\"inputmode\"\r\n        [patterns]=\"maskPatterns\"\r\n        [allowNegativeNumbers]=\"false\"\r\n        [thousandSeparator]=\"' '\"\r\n        [decimalMarker]=\"'.'\"\r\n        [validation]=\"config.maskValidation || false\"\r\n        [specialCharacters]=\"specialCharacters\"\r\n        [dropSpecialCharacters]=\"dropSpecialCharacters\"\r\n        [tabindex]=\"tabIndex\"\r\n      />\r\n    } @else {\r\n      <input class=\"trm-form-field trm-input\"\r\n             [matDatepicker]=\"matDatepicker\"\r\n             [formControl]=\"control\"\r\n             [placeholder]=\"config.placeholder | trans\"\r\n             (input)=\"onDateInput($event)\"\r\n             [attr.inputmode]=\"inputmode\"\r\n             (blur)=\"onTouch()\"\r\n             [min]=\"config?.options?.min\"\r\n             [max]=\"config?.options?.max\"\r\n             [tabindex]=\"tabIndex\"\r\n             type=\"text\"\r\n             [name]=\"name\"\r\n             [id]=\"name\"\r\n      />\r\n    }\r\n    <ng-content select=\"[app-c-text-suffix]\"></ng-content>\r\n  </div>\r\n  @if (config.description) {\r\n    <div class=\"c-text__hint\"\r\n         [innerHTML]=\"config.description | trans\"></div>\r\n  }\r\n  <ng-content select=\"[app-c-text-hint]\"></ng-content>\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('email') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_EMAIL | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('min') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_MIN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('max') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_MAX | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('pattern') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('mask') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\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  @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"]}
196
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constructor-field-text.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.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  forwardRef,\r\n  inject,\r\n  Injector,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport { FORMAT_DATE, PaymentField, PaymentFieldTypeEnum } 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 { Subject } from 'rxjs';\r\nimport { MatDatepicker, MatDatepickerInput } from '@angular/material/datepicker';\r\nimport momentjs from 'moment-timezone';\r\nimport { insertRemoveTrigger } from './../../../../../helpers/insertRemoveTrigger';\r\nimport { INITIAL_PHONE_MASK, MaskResolver } from './../../../../../helpers/mask-resolver';\r\nimport { IConfig, NgxMaskDirective, NgxMaskPipe } from 'ngx-mask';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { removeSpecSymbols } from '../../../../../helpers/phone-codes';\r\nimport { InputMaskCorrector } from '../../../../directives/input-mask-corrector.directive';\r\nimport { TabIndexFocusDirective } from '../../../../directives/tab-index-focus.directive';\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\n\r\n@Component({\r\n  selector: 'app-constructor-field-text',\r\n  templateUrl: './constructor-field-text.component.html',\r\n  styleUrls: ['./constructor-field-text.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(() => ConstructorFieldTextComponent),\r\n      multi: true\r\n    }\r\n  ],\r\n  standalone: true,\r\n  imports: [FormsModule, NgxMaskDirective, InputMaskCorrector, ReactiveFormsModule, TabIndexFocusDirective, MatDatepickerInput, TranslateByKeyPipe]\r\n})\r\nexport class ConstructorFieldTextComponent implements ControlValueAccessor, OnInit, OnDestroy, AfterViewInit {\r\n  private cd = inject(ChangeDetectorRef);\r\n  private maskSrv = inject(MaskResolver);\r\n  private injector = inject(Injector);\r\n  private maskPipe = inject(NgxMaskPipe);\r\n\r\n  private unsub: Subject<void> = new Subject<void>();\r\n  private _type = 'text';\r\n\r\n  get disabled() {\r\n    return this.config.readonly || false;\r\n  };\r\n\r\n  readonly FORMAT_DATE = FORMAT_DATE;\r\n  mask: string;\r\n  dropSpecialCharacters = true;\r\n  I18N_KEY = I18N_KEY;\r\n\r\n  @Input() config: PaymentField;\r\n\r\n  get inputmode(): \"text\" | \"tel\" | \"numeric\" | \"email\" | \"url\" | \"none\" {\r\n    return this.config.inputMode || 'text';\r\n  }\r\n\r\n  @Input() matDatepicker: MatDatepicker<momentjs.Moment>;\r\n  @Input() tabIndex: number;\r\n  @Output() maskedValueChange: EventEmitter<string> = new EventEmitter();\r\n  control: AbstractControl;\r\n  @ViewChild(NgxMaskDirective) dir: NgxMaskDirective;\r\n  maskPatterns: IConfig['patterns'];\r\n  specialCharacters: string[];\r\n  onChange = (_value: any) => {\r\n  };\r\n  onTouch = () => {\r\n  };\r\n\r\n  constructor() {\r\n  }\r\n\r\n  get type() {\r\n    if (this.config.type === PaymentFieldTypeEnum.Email) {\r\n      return 'email';\r\n    }\r\n    return this._type;\r\n  }\r\n\r\n  get name() {\r\n    return this.config.name;\r\n  }\r\n\r\n  onDateInput(e: InputEvent) {\r\n    const target: HTMLInputElement = e.target as HTMLInputElement;\r\n    let {selectionStart, selectionEnd} = target;\r\n    this.control?.markAsUntouched();\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    target.value = this.maskPipe\r\n      .transform(target.value, this.mask, {patterns: this.maskPatterns})\r\n      .replace(/^-|-$/, '');\r\n\r\n    setTimeout(() => {\r\n      this.control?.updateValueAndValidity();\r\n\r\n      if (selectionStart === selectionEnd && e.inputType !== 'deleteContentBackward') {\r\n        while (this.specialCharacters.includes(target.value[selectionEnd - 1])) {\r\n          selectionEnd += 1;\r\n          selectionStart += 1;\r\n        }\r\n      }\r\n      target.setSelectionRange(selectionStart, selectionEnd);\r\n    });\r\n  }\r\n\r\n  onPaste(e: ClipboardEvent) {\r\n    const t = e.target as HTMLInputElement;\r\n    if (this.type === PaymentFieldTypeEnum.Email) {\r\n      this._emitMaskedValueChanges(t);\r\n      return;\r\n    }\r\n    const value = t.value;\r\n    let content = e.clipboardData?.getData('text') || '';\r\n    let selectionStart = removeSpecSymbols(t.value.slice(0, t.selectionStart)).length + removeSpecSymbols(content).length;\r\n    if (value) {\r\n      const arr = Array.from(value);\r\n      arr.splice(t.selectionStart, t.selectionEnd - t.selectionStart, ...Array.from(content));\r\n      content = removeSpecSymbols(arr.join(''));\r\n    }\r\n    this.mask = this.maskSrv.getMaskByValue(this.config.mask, content);\r\n    this.cd.detectChanges();\r\n    this.control?.setValue(content);\r\n    this.cd.detectChanges();\r\n    e.preventDefault();\r\n    this._emitMaskedValueChanges(t, selectionStart);\r\n  }\r\n\r\n  onInput(e: InputEvent) {\r\n    this.control?.markAsUntouched();\r\n    this.cd.markForCheck();\r\n    if (this.matDatepicker) {\r\n      return;\r\n    }\r\n    const target = e.target as HTMLInputElement;\r\n    if (this.type === PaymentFieldTypeEnum.Email) {\r\n      this._emitMaskedValueChanges(target);\r\n      return;\r\n    }\r\n    const value: string = this.control?.value;\r\n    let selectionStart = removeSpecSymbols(target.value.slice(0, target.selectionStart)).length;\r\n    const mask = this.maskSrv.getMaskByValue(this.config.mask, value);\r\n    if (!mask || mask === INITIAL_PHONE_MASK) {\r\n      return;\r\n    }\r\n    this.mask = mask;\r\n\r\n    this.cd.detectChanges();\r\n    this._emitMaskedValueChanges(target, selectionStart);\r\n  }\r\n\r\n  private _emitMaskedValueChanges(target, positionInUnmaskedValue?) {\r\n    setTimeout(() => {\r\n      this.control?.updateValueAndValidity();\r\n      if (this.mask) {\r\n        this.maskedValueChange.emit(target.value);\r\n      }\r\n      this._setSelection(target, positionInUnmaskedValue);\r\n    });\r\n  }\r\n\r\n  private _setSelection(target: HTMLInputElement, positionInUnmaskedValue?) {\r\n    if (this.type === PaymentFieldTypeEnum.Email) {\r\n      return;\r\n    }\r\n    let positionMaskedValue = 0;\r\n    let i = 0;\r\n    while (positionInUnmaskedValue > i && target.value.length > positionMaskedValue) {\r\n      if (/\\d/.test(target.value[positionMaskedValue])) {\r\n        i++;\r\n      }\r\n      positionMaskedValue++;\r\n    }\r\n    target.setSelectionRange(positionMaskedValue, positionMaskedValue);\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  get apiError(): string {\r\n    return this.control?.getError('error');\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  writeValue(value: any) {\r\n    if (value) {\r\n      this.mask = this.maskSrv.getMaskByValue(this.config.mask, value);\r\n    }\r\n    this.cd.markForCheck();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.mask = this.maskSrv.getMaskByValue(this.config.mask);\r\n    if (this.config.maskValidation !== true) {\r\n      this.config.maskValidation = false;\r\n    }\r\n    this.maskPatterns = this.maskSrv.getPatterns(this.config);\r\n    this.specialCharacters = [...this.maskSrv.getSpecialCharacters(this.config)];\r\n    this.dropSpecialCharacters = this.config.dropSpecialCharacters !== false;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.unsub.next();\r\n    this.unsub.unsubscribe();\r\n  }\r\n}\r\n","@if (control) {\r\n  <label class=\"trm-label\"\r\n         [for]=\"config.name\"\r\n  > {{ config.label | trans }} </label>\r\n  <div class=\"input-wrapper trm-form-field-wrapper c-text\"\r\n       [class.c-text--disabled]=\"disabled\"\r\n       [class.c-text--uppercase]=\"config.uppercase\">\r\n    @if (!matDatepicker) {\r\n      <input\r\n        class=\"trm-form-field trm-input\"\r\n        [class.trm-form-field--disabled]=\"disabled\"\r\n        [placeholder]=\"config.placeholder | trans\"\r\n        (blur)=\"onTouch()\"\r\n        [formControl]=\"control\"\r\n        (input)=\"onInput($event)\"\r\n        (paste)=\"onPaste($event)\"\r\n        [type]=\"type\"\r\n        [name]=\"name\"\r\n        [id]=\"name\"\r\n        [mask]=\"mask\"\r\n        [attr.inputmode]=\"inputmode\"\r\n        [patterns]=\"maskPatterns\"\r\n        [allowNegativeNumbers]=\"false\"\r\n        [thousandSeparator]=\"' '\"\r\n        [decimalMarker]=\"'.'\"\r\n        [validation]=\"config.maskValidation || false\"\r\n        [specialCharacters]=\"specialCharacters\"\r\n        [dropSpecialCharacters]=\"dropSpecialCharacters\"\r\n        [tabindex]=\"tabIndex\"\r\n      />\r\n    } @else {\r\n      <input class=\"trm-form-field trm-input\"\r\n             [matDatepicker]=\"matDatepicker\"\r\n             [formControl]=\"control\"\r\n             [placeholder]=\"config.placeholder | trans\"\r\n             (input)=\"onDateInput($event)\"\r\n             [attr.inputmode]=\"inputmode\"\r\n             (blur)=\"onTouch()\"\r\n             [min]=\"config?.options?.min\"\r\n             [max]=\"config?.options?.max\"\r\n             [tabindex]=\"tabIndex\"\r\n             type=\"text\"\r\n             [name]=\"name\"\r\n             [id]=\"name\"\r\n      />\r\n    }\r\n    <ng-content select=\"[app-c-text-suffix]\"></ng-content>\r\n  </div>\r\n  @if (config.description) {\r\n    <div class=\"c-text__hint\"\r\n         [innerHTML]=\"config.description | trans\"></div>\r\n  }\r\n  <ng-content select=\"[app-c-text-hint]\"></ng-content>\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('email') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_EMAIL | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('min') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_MIN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('max') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_MAX | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('pattern') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('mask') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\r\n    </div>\r\n  }\r\n  @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\r\n    <div class=\"trm-error\"\r\n         @insertRemove\r\n    >\r\n      {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\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  @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"]}
@@ -1,3 +1,5 @@
1
+ export * from "./constructor-field-iframe/iframe-validator-directive.directive";
2
+ export * from "./constructor-field-iframe/card-sdk.service";
1
3
  export * from './constructor-field-date/constructor-field-date.component';
2
4
  export * from './constructor-field-iframe/constructor-field-iframe.component';
3
5
  export * from './constructor-field-select/constructor-field-select.component';
@@ -5,4 +7,4 @@ export * from './constructor-field-text/constructor-field-text.component';
5
7
  export * from './constructor-preparation/constructor-preparation.component';
6
8
  export * from './method-amount-hint/method-amount-hint.component';
7
9
  export * from './ps-select/ps-select.component';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90ZXJtaW5hbC10ZW1wbGF0ZS9zcmMvbGliL2FwcC9wYWdlcy9jb21wb25lbnRzL2NvbnN0cnVjdG9yLWZvcm0vY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYywrREFBK0QsQ0FBQztBQUM5RSxjQUFjLDJEQUEyRCxDQUFDO0FBQzFFLGNBQWMsNkRBQTZELENBQUM7QUFDNUUsY0FBYyxtREFBbUQsQ0FBQztBQUNsRSxjQUFjLGlDQUFpQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb25zdHJ1Y3Rvci1maWVsZC1kYXRlL2NvbnN0cnVjdG9yLWZpZWxkLWRhdGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb25zdHJ1Y3Rvci1maWVsZC1pZnJhbWUvY29uc3RydWN0b3ItZmllbGQtaWZyYW1lLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RydWN0b3ItZmllbGQtc2VsZWN0L2NvbnN0cnVjdG9yLWZpZWxkLXNlbGVjdC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdG9yLWZpZWxkLXRleHQvY29uc3RydWN0b3ItZmllbGQtdGV4dC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdG9yLXByZXBhcmF0aW9uL2NvbnN0cnVjdG9yLXByZXBhcmF0aW9uLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbWV0aG9kLWFtb3VudC1oaW50L21ldGhvZC1hbW91bnQtaGludC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BzLXNlbGVjdC9wcy1zZWxlY3QuY29tcG9uZW50JztcclxuIl19
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90ZXJtaW5hbC10ZW1wbGF0ZS9zcmMvbGliL2FwcC9wYWdlcy9jb21wb25lbnRzL2NvbnN0cnVjdG9yLWZvcm0vY29tcG9uZW50cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGlFQUFpRSxDQUFDO0FBQ2hGLGNBQWMsNkNBQTZDLENBQUM7QUFFNUQsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLCtEQUErRCxDQUFDO0FBQzlFLGNBQWMsK0RBQStELENBQUM7QUFDOUUsY0FBYywyREFBMkQsQ0FBQztBQUMxRSxjQUFjLDZEQUE2RCxDQUFDO0FBQzVFLGNBQWMsbURBQW1ELENBQUM7QUFDbEUsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2NvbnN0cnVjdG9yLWZpZWxkLWlmcmFtZS9pZnJhbWUtdmFsaWRhdG9yLWRpcmVjdGl2ZS5kaXJlY3RpdmVcIjtcclxuZXhwb3J0ICogZnJvbSBcIi4vY29uc3RydWN0b3ItZmllbGQtaWZyYW1lL2NhcmQtc2RrLnNlcnZpY2VcIjtcclxuXHJcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RydWN0b3ItZmllbGQtZGF0ZS9jb25zdHJ1Y3Rvci1maWVsZC1kYXRlLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29uc3RydWN0b3ItZmllbGQtaWZyYW1lL2NvbnN0cnVjdG9yLWZpZWxkLWlmcmFtZS5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL2NvbnN0cnVjdG9yLWZpZWxkLXNlbGVjdC9jb25zdHJ1Y3Rvci1maWVsZC1zZWxlY3QuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb25zdHJ1Y3Rvci1maWVsZC10ZXh0L2NvbnN0cnVjdG9yLWZpZWxkLXRleHQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb25zdHJ1Y3Rvci1wcmVwYXJhdGlvbi9jb25zdHJ1Y3Rvci1wcmVwYXJhdGlvbi5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL21ldGhvZC1hbW91bnQtaGludC9tZXRob2QtYW1vdW50LWhpbnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9wcy1zZWxlY3QvcHMtc2VsZWN0LmNvbXBvbmVudCc7XHJcbiJdfQ==
@@ -1,7 +1,6 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, inject, Input } from '@angular/core';
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DestroyRef, forwardRef, inject, Input } from '@angular/core';
2
2
  import { FormControl, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
3
- import { Subject } from 'rxjs';
4
- import { filter, takeUntil } from 'rxjs/operators';
3
+ import { filter } from 'rxjs/operators';
5
4
  import { MethodTitlePipe } from './../../../../../pipes/method-title.pipe';
6
5
  import { TranslatePipe } from '@ngx-translate/core';
7
6
  import { I18N_KEY } from './../../../../../i18n';
@@ -10,9 +9,24 @@ import { TabIndexFocusDirective } from '../../../../directives/tab-index-focus.d
10
9
  import { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';
11
10
  import { TrmSelectLabelTemplateDirective } from '../../../../../shared/components/trm-select/trm-select-label-template.directive';
12
11
  import { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';
12
+ import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
13
13
  import * as i0 from "@angular/core";
14
14
  import * as i1 from "@angular/forms";
15
15
  export class PsSelectComponent {
16
+ constructor() {
17
+ this.cd = inject(ChangeDetectorRef);
18
+ this.methodTitlePipe = inject(MethodTitlePipe);
19
+ this.translatePipe = inject(TranslatePipe);
20
+ this.destroyRef = inject(DestroyRef);
21
+ this.I18N_KEY = I18N_KEY;
22
+ this.onChange = (_value) => {
23
+ };
24
+ this.onTouch = () => {
25
+ };
26
+ this.methods = [];
27
+ this.disabled = false;
28
+ this.otherMethodControl = new FormControl(undefined);
29
+ }
16
30
  get popularMethods() {
17
31
  if (this.disabled) {
18
32
  return null;
@@ -36,24 +50,10 @@ export class PsSelectComponent {
36
50
  }
37
51
  });
38
52
  }
39
- constructor() {
40
- this.cd = inject(ChangeDetectorRef);
41
- this.methodTitlePipe = inject(MethodTitlePipe);
42
- this.translatePipe = inject(TranslatePipe);
43
- this.unsub = new Subject();
44
- this.I18N_KEY = I18N_KEY;
45
- this.onChange = (_value) => {
46
- };
47
- this.onTouch = () => {
48
- };
49
- this.methods = [];
50
- this.disabled = false;
51
- this.otherMethodControl = new FormControl(undefined);
52
- }
53
53
  ngOnInit() {
54
54
  this.otherMethodControl
55
55
  .valueChanges
56
- .pipe(filter(m => !!m), takeUntil(this.unsub))
56
+ .pipe(filter(m => !!m), takeUntilDestroyed(this.destroyRef))
57
57
  .subscribe((method) => this.selectMethod(method));
58
58
  }
59
59
  selectMethod(method, options = { emitChange: true }) {
@@ -94,10 +94,6 @@ export class PsSelectComponent {
94
94
  this.searchString = value;
95
95
  this.cd.markForCheck();
96
96
  }
97
- ngOnDestroy() {
98
- this.unsub.next();
99
- this.unsub.unsubscribe();
100
- }
101
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: PsSelectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
102
98
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: PsSelectComponent, isStandalone: true, selector: "app-ps-select", inputs: { methods: "methods", tabIndex: "tabIndex" }, providers: [
103
99
  {
@@ -120,9 +116,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
120
116
  MethodTitlePipe,
121
117
  TranslatePipe
122
118
  ], standalone: true, imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe], template: "<label class=\"trm-label\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\r\n</label>\r\n<ul class=\"methods\">\r\n @for (method of popularMethods; track method.id) {\r\n <li class=\"method\"\r\n [class.method--selected]=\"selectedType === method.id\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\r\n (blur)=\"onTouch()\"\r\n (click)=\"selectMethod(method.id)\"\r\n >\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+method.name\"\r\n ></span>\r\n <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\r\n </li>\r\n }\r\n @if (searchString || otherMethods.length) {\r\n <li class=\"methods__other\">\r\n <app-trm-select [data]=\"otherMethods\"\r\n idLabel=\"method\"\r\n (search)=\"search($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"otherMethodControl\"\r\n [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\r\n class=\"c-field-select trm-form-field\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+item.name\"></span>\r\n <span class=\"method__name\"\r\n [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </li>\r\n }\r\n</ul>\r\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\r\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\r\n\r\n", styles: [":host{display:block}.methods{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:flex-start;list-style:none;flex-wrap:wrap;margin:0;padding:0}.methods .method{--method-color: var(--ps-select-color, var(--color-base-350));--method-border-color: var(--ps-select-border-color, var(--color-base-200));display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start;box-sizing:border-box;flex:100%;max-width:calc(50% - 5px);padding:16px;border:1px solid var(--method-border-color);border-radius:10px;outline:0;align-self:stretch}.methods .method:hover,.methods .method:focus{--method-color: var(--ps-select-color--hover, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--hover, var(--color-primary-500));cursor:pointer;box-shadow:0 0 15px -1px #a378ff26}.methods .method.method--selected{--method-color: var(--ps-select-color--active, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--active, var(--color-primary-500));cursor:default;box-shadow:0 0 0 2px var(--method-border-color);outline:none}.methods .method__icon{background:transparent no-repeat 100% 100%;background-size:contain;width:24px;height:24px;flex-shrink:0}.methods .method__name{font-weight:600;font-size:14px;line-height:18px;color:var(--method-color);white-space:normal;overflow:hidden;max-width:100%;text-overflow:ellipsis;flex-shrink:0}.methods__other{box-sizing:border-box;flex:100%;margin-top:10px}\n"] }]
123
- }], ctorParameters: () => [], propDecorators: { methods: [{
119
+ }], propDecorators: { methods: [{
124
120
  type: Input
125
121
  }], tabIndex: [{
126
122
  type: Input
127
123
  }] } });
128
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ps-select.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,WAAW,EAAE,WAAW,EAAE,iBAAiB,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACxH,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,0CAA0C,CAAC;AAC3E,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,sBAAsB,EAAE,MAAM,kDAAkD,CAAC;AAC1F,OAAO,EAAE,kBAAkB,EAAE,MAAM,kEAAkE,CAAC;AACtG,OAAO,EACL,+BAA+B,EAChC,MAAM,iFAAiF,CAAC;AACzF,OAAO,EAAE,kBAAkB,EAAE,MAAM,mDAAmD,CAAC;;;AAmBvF,MAAM,OAAO,iBAAiB;IAmB1B,IAAI,cAAc;QACd,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC;QAChB,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,YAAY;QACZ,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QACjC,CAAC;QACD,OAAO,IAAI,CAAC,OAAO;aACd,KAAK,CAAC,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC;aACjC,MAAM,CAAC,CAAC,CAAiB,EAAE,EAAE;YAC1B,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBACrB,OAAO,IAAI,CAAC;YAChB,CAAC;iBAAM,CAAC;gBACR,MAAM,KAAK,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAC1C,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CACzC,CAAC;gBACF,OAAO,KAAK,CAAC,WAAW,EAAE;qBACjB,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CACZ,EAAE,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CACjF,CAAC;YACV,CAAC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED;QA9CQ,OAAE,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAC/B,oBAAe,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC1C,kBAAa,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAEtC,UAAK,GAAkB,IAAI,OAAO,EAAQ,CAAC;QACnD,aAAQ,GAAG,QAAQ,CAAC;QACpB,aAAQ,GAAG,CAAC,MAAM,EAAE,EAAE;QACtB,CAAC,CAAC;QACF,YAAO,GAAG,GAAG,EAAE;QACf,CAAC,CAAC;QACO,YAAO,GAAqB,EAAE,CAAC;QACxC,aAAQ,GAAG,KAAK,CAAC;QAIV,uBAAkB,GAAgB,IAAI,WAAW,CAAS,SAAS,CAAC,CAAC;IAiC5E,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,kBAAkB;aAClB,YAAY;aACZ,IAAI,CACD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,EAChB,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CACxB;aACA,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC;IAC1D,CAAC;IAED,YAAY,CAAC,MAAc,EAAE,UAAmC,EAAC,UAAU,EAAE,IAAI,EAAC;QAC9E,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,YAAY,KAAK,MAAM,EAAE,CAAC;YAC1C,OAAO;QACX,CAAC;QACD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC3B,IAAI,OAAO,EAAE,UAAU,EAAE,CAAC;YACtB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC1B,CAAC;QACD,MAAM,cAAc,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,MAAM,CAAC,CAAC;QACpE,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EAAE,EAAC,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;IAC9G,CAAC;IAED,UAAU,CAAC,MAAc;QACrB,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,EAAC,UAAU,EAAE,KAAK,EAAC,CAAC,CAAC;IACnD,CAAC;IAED,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAChC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAA;QAC1B,IAAI,UAAU,EAAE,CAAC;YACb,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;gBACtD,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,EAAE,EAAC,SAAS,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;YAC5F,CAAC;YACD,IAAI,CAAC,kBAAkB,CAAC,OAAO,EAAE,CAAC;QACtC,CAAC;aAAM,CAAC;YACJ,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC;QACrC,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;IAC5B,CAAC;IAED,MAAM,CAAC,KAAK;QACR,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,EAAE,CAAC,YAAY,EAAE,CAAC;IAC3B,CAAC;IAED,WAAW;QACP,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;QAClB,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;IAC7B,CAAC;8GA3GQ,iBAAiB;kGAAjB,iBAAiB,kHAZf;YACP;gBACI,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;gBAChD,KAAK,EAAE,IAAI;aACd;YACH,eAAe;YACf,aAAa;SACd,0BCtCL,moDA0CA,qgDDFc,sBAAsB,uDAAE,OAAO,oFAAE,kBAAkB,uNAAE,WAAW,sIAAE,mBAAmB,kNAAE,+BAA+B,gEAAE,eAAe,gDAAE,kBAAkB;;2FAE5J,iBAAiB;kBAjB7B,SAAS;+BACI,eAAe,mBAGR,uBAAuB,CAAC,MAAM,aACpC;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,kBAAkB,CAAC;4BAChD,KAAK,EAAE,IAAI;yBACd;wBACH,eAAe;wBACf,aAAa;qBACd,cACW,IAAI,WACP,CAAC,sBAAsB,EAAE,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,mBAAmB,EAAE,+BAA+B,EAAE,eAAe,EAAE,kBAAkB,CAAC;wDAa7J,OAAO;sBAAf,KAAK;gBAEG,QAAQ;sBAAhB,KAAK","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  forwardRef,\r\n  inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, FormControl, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { Subject } from 'rxjs';\r\nimport { MethodTypeType } from '../../../../../../codegen/model/models';\r\nimport { filter, takeUntil } from 'rxjs/operators';\r\nimport { MethodTitlePipe } from './../../../../../pipes/method-title.pipe';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { NgClass } from '@angular/common';\r\nimport { TabIndexFocusDirective } from '../../../../directives/tab-index-focus.directive';\r\nimport { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';\r\nimport {\r\n  TrmSelectLabelTemplateDirective\r\n} from '../../../../../shared/components/trm-select/trm-select-label-template.directive';\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\n\r\n@Component({\r\n    selector: 'app-ps-select',\r\n    templateUrl: './ps-select.component.html',\r\n    styleUrls: ['./ps-select.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => PsSelectComponent),\r\n            multi: true,\r\n        },\r\n      MethodTitlePipe,\r\n      TranslatePipe\r\n    ],\r\n    standalone: true,\r\n    imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe]\r\n})\r\nexport class PsSelectComponent implements OnDestroy, OnInit, ControlValueAccessor {\r\n    private cd = inject(ChangeDetectorRef);\r\n    private methodTitlePipe = inject(MethodTitlePipe);\r\n    private translatePipe = inject(TranslatePipe);\r\n\r\n    private unsub: Subject<void> = new Subject<void>();\r\n    I18N_KEY = I18N_KEY;\r\n    onChange = (_value) => {\r\n    };\r\n    onTouch = () => {\r\n    };\r\n    @Input() methods: MethodTypeType[] = [];\r\n    disabled = false;\r\n    @Input() tabIndex: number;\r\n\r\n    selectedType: number;\r\n    public otherMethodControl: FormControl = new FormControl<number>(undefined);\r\n    searchString: string;\r\n\r\n    get popularMethods(): MethodTypeType[] {\r\n        if (this.disabled) {\r\n            return null;\r\n        }\r\n        return this.methods.slice(0, 4);\r\n    }\r\n\r\n    get otherMethods(): MethodTypeType[] {\r\n        if (this.disabled) {\r\n            return this.methods.slice(0);\r\n        }\r\n        return this.methods\r\n            .slice(this.popularMethods.length)\r\n            .filter((m: MethodTypeType) => {\r\n                if (!this.searchString) {\r\n                    return true;\r\n                } else {\r\n                const title: string = this.translatePipe.transform(\r\n                        this.methodTitlePipe.transform(m.name)\r\n                    );\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\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.otherMethodControl\r\n            .valueChanges\r\n            .pipe(\r\n                filter(m => !!m),\r\n                takeUntil(this.unsub)\r\n            )\r\n            .subscribe((method) => this.selectMethod(method));\r\n    }\r\n\r\n    selectMethod(method: number, options: { emitChange: boolean } = {emitChange: true}) {\r\n        if (!method || this.selectedType === method) {\r\n            return;\r\n        }\r\n        this.selectedType = method;\r\n        if (options?.emitChange) {\r\n            this.onChange(method);\r\n        }\r\n        const hasInOtherList = this.otherMethods.some(m => m.id === method);\r\n        this.otherMethodControl.setValue(hasInOtherList ? method : undefined, {emitEvent: false, onlySelf: true});\r\n    }\r\n\r\n    writeValue(method: number) {\r\n        this.cd.detectChanges();\r\n        this.selectMethod(method, {emitChange: false});\r\n    }\r\n\r\n    registerOnTouched(fn: any) {\r\n        this.onTouch = fn;\r\n    }\r\n\r\n    registerOnChange(fn: any) {\r\n        this.onChange = fn;\r\n    }\r\n\r\n    setDisabledState(isDisabled: boolean) {\r\n        this.disabled = isDisabled\r\n        if (isDisabled) {\r\n            if (!this.otherMethodControl.value && this.selectedType) {\r\n                this.otherMethodControl.setValue(this.selectedType, {emitEvent: false, onlySelf: true});\r\n            }\r\n            this.otherMethodControl.disable();\r\n        } else {\r\n            this.otherMethodControl.enable();\r\n        }\r\n        this.cd.detectChanges();\r\n    }\r\n\r\n    search(value) {\r\n        this.searchString = value;\r\n        this.cd.markForCheck();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this.unsub.next();\r\n        this.unsub.unsubscribe();\r\n    }\r\n}\r\n","<label class=\"trm-label\">\r\n  {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\r\n</label>\r\n<ul class=\"methods\">\r\n  @for (method of popularMethods; track method.id) {\r\n    <li class=\"method\"\r\n      [class.method--selected]=\"selectedType === method.id\"\r\n      [tabindex]=\"tabIndex\"\r\n      (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\r\n      (blur)=\"onTouch()\"\r\n      (click)=\"selectMethod(method.id)\"\r\n      >\r\n      <span class=\"method__icon\"\r\n        [ngClass]=\"'ps-icon-'+method.name\"\r\n      ></span>\r\n      <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\r\n    </li>\r\n  }\r\n  @if (searchString || otherMethods.length) {\r\n    <li class=\"methods__other\">\r\n      <app-trm-select [data]=\"otherMethods\"\r\n        idLabel=\"method\"\r\n        (search)=\"search($event)\"\r\n        [tabIndex]=\"tabIndex\"\r\n        (open)=\"onTouch()\"\r\n        [formControl]=\"otherMethodControl\"\r\n        [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\r\n        class=\"c-field-select trm-form-field\"\r\n        >\r\n        <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n          <span class=\"method__icon\"\r\n          [ngClass]=\"'ps-icon-'+item.name\"></span>\r\n          <span class=\"method__name\"\r\n          [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\r\n        </ng-template>\r\n      </app-trm-select>\r\n    </li>\r\n  }\r\n</ul>\r\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\r\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\r\n\r\n"]}
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ps-select.component.js","sourceRoot":"","sources":["../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.ts","../../../../../../../../../../projects/terminal-template/src/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  DestroyRef,\r\n  forwardRef,\r\n  inject,\r\n  Input,\r\n  OnInit\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, FormControl, FormsModule, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';\r\nimport { MethodTypeType } from '../../../../../../codegen/model/models';\r\nimport { filter } from 'rxjs/operators';\r\nimport { MethodTitlePipe } from './../../../../../pipes/method-title.pipe';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18N_KEY } from './../../../../../i18n';\r\nimport { NgClass } from '@angular/common';\r\nimport { TabIndexFocusDirective } from '../../../../directives/tab-index-focus.directive';\r\nimport { TrmSelectComponent } from '../../../../../shared/components/trm-select/trm-select.component';\r\nimport {\r\n  TrmSelectLabelTemplateDirective\r\n} from '../../../../../shared/components/trm-select/trm-select-label-template.directive';\r\nimport { TranslateByKeyPipe } from '../../../../../shared/pipes/translate-by-key.pipe';\r\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\r\n\r\n@Component({\r\n  selector: 'app-ps-select',\r\n  templateUrl: './ps-select.component.html',\r\n  styleUrls: ['./ps-select.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => PsSelectComponent),\r\n      multi: true,\r\n    },\r\n    MethodTitlePipe,\r\n    TranslatePipe\r\n  ],\r\n  standalone: true,\r\n  imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe]\r\n})\r\nexport class PsSelectComponent implements OnInit, ControlValueAccessor {\r\n  private cd = inject(ChangeDetectorRef);\r\n  private methodTitlePipe = inject(MethodTitlePipe);\r\n  private translatePipe = inject(TranslatePipe);\r\n  private destroyRef: DestroyRef = inject(DestroyRef);\r\n  I18N_KEY = I18N_KEY;\r\n  onChange = (_value) => {\r\n  };\r\n  onTouch = () => {\r\n  };\r\n  @Input() methods: MethodTypeType[] = [];\r\n  disabled = false;\r\n  @Input() tabIndex: number;\r\n\r\n  selectedType: number;\r\n  otherMethodControl: FormControl = new FormControl<number>(undefined);\r\n  searchString: string;\r\n\r\n  get popularMethods(): MethodTypeType[] {\r\n    if (this.disabled) {\r\n      return null;\r\n    }\r\n    return this.methods.slice(0, 4);\r\n  }\r\n\r\n  get otherMethods(): MethodTypeType[] {\r\n    if (this.disabled) {\r\n      return this.methods.slice(0);\r\n    }\r\n    return this.methods\r\n      .slice(this.popularMethods.length)\r\n      .filter((m: MethodTypeType) => {\r\n        if (!this.searchString) {\r\n          return true;\r\n        } else {\r\n          const title: string = this.translatePipe.transform(\r\n            this.methodTitlePipe.transform(m.name)\r\n          );\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  ngOnInit() {\r\n    this.otherMethodControl\r\n      .valueChanges\r\n      .pipe(\r\n        filter(m => !!m),\r\n        takeUntilDestroyed(this.destroyRef)\r\n      )\r\n      .subscribe((method) => this.selectMethod(method));\r\n  }\r\n\r\n  selectMethod(method: number, options: { emitChange: boolean } = {emitChange: true}) {\r\n    if (!method || this.selectedType === method) {\r\n      return;\r\n    }\r\n    this.selectedType = method;\r\n    if (options?.emitChange) {\r\n      this.onChange(method);\r\n    }\r\n    const hasInOtherList = this.otherMethods.some(m => m.id === method);\r\n    this.otherMethodControl.setValue(hasInOtherList ? method : undefined, {emitEvent: false, onlySelf: true});\r\n  }\r\n\r\n  writeValue(method: number) {\r\n    this.cd.detectChanges();\r\n    this.selectMethod(method, {emitChange: false});\r\n  }\r\n\r\n  registerOnTouched(fn: any) {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.disabled = isDisabled\r\n    if (isDisabled) {\r\n      if (!this.otherMethodControl.value && this.selectedType) {\r\n        this.otherMethodControl.setValue(this.selectedType, {emitEvent: false, onlySelf: true});\r\n      }\r\n      this.otherMethodControl.disable();\r\n    } else {\r\n      this.otherMethodControl.enable();\r\n    }\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  search(value: string) {\r\n    this.searchString = value;\r\n    this.cd.markForCheck();\r\n  }\r\n}\r\n","<label class=\"trm-label\">\r\n  {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\r\n</label>\r\n<ul class=\"methods\">\r\n  @for (method of popularMethods; track method.id) {\r\n    <li class=\"method\"\r\n      [class.method--selected]=\"selectedType === method.id\"\r\n      [tabindex]=\"tabIndex\"\r\n      (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\r\n      (blur)=\"onTouch()\"\r\n      (click)=\"selectMethod(method.id)\"\r\n      >\r\n      <span class=\"method__icon\"\r\n        [ngClass]=\"'ps-icon-'+method.name\"\r\n      ></span>\r\n      <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\r\n    </li>\r\n  }\r\n  @if (searchString || otherMethods.length) {\r\n    <li class=\"methods__other\">\r\n      <app-trm-select [data]=\"otherMethods\"\r\n        idLabel=\"method\"\r\n        (search)=\"search($event)\"\r\n        [tabIndex]=\"tabIndex\"\r\n        (open)=\"onTouch()\"\r\n        [formControl]=\"otherMethodControl\"\r\n        [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\r\n        class=\"c-field-select trm-form-field\"\r\n        >\r\n        <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n          <span class=\"method__icon\"\r\n          [ngClass]=\"'ps-icon-'+item.name\"></span>\r\n          <span class=\"method__name\"\r\n          [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\r\n        </ng-template>\r\n      </app-trm-select>\r\n    </li>\r\n  }\r\n</ul>\r\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\r\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\r\n\r\n"]}