trm-tmpl 4.0.1 → 5.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +32 -0
- package/README.md +24 -24
- package/assets/svg/arrow_down.svg +3 -3
- package/assets/svg/currencies/brl.svg +5 -5
- package/assets/svg/currencies/btc.svg +4 -4
- package/assets/svg/currencies/cny.svg +4 -4
- package/assets/svg/currencies/eth.svg +9 -9
- package/assets/svg/currencies/eur.svg +4 -4
- package/assets/svg/currencies/gbp.svg +4 -4
- package/assets/svg/currencies/kzt.svg +4 -4
- package/assets/svg/currencies/mxn.svg +5 -5
- package/assets/svg/currencies/rub.svg +4 -4
- package/assets/svg/currencies/trx.svg +11 -11
- package/assets/svg/currencies/uah.svg +4 -4
- package/assets/svg/currencies/usd.svg +4 -4
- package/assets/svg/currencies/usdt.svg +4 -4
- package/assets/svg/datepicker.svg +9 -9
- package/assets/svg/es.svg +573 -573
- package/assets/svg/flags/ab.svg +23 -23
- package/assets/svg/flags/os.svg +12 -12
- package/assets/svg/flags/other.svg +19 -19
- package/assets/svg/pay/advcash.svg +6 -6
- package/assets/svg/pay/alfabank.svg +5 -5
- package/assets/svg/pay/alipay.svg +5 -5
- package/assets/svg/pay/alipay_plus.svg +6 -6
- package/assets/svg/pay/applepay.svg +4 -4
- package/assets/svg/pay/argentina_bank.svg +74 -74
- package/assets/svg/pay/atf24.svg +14 -14
- package/assets/svg/pay/baloto.svg +8 -8
- package/assets/svg/pay/bancontact.svg +16 -16
- package/assets/svg/pay/beeline.svg +19 -19
- package/assets/svg/pay/bitcoin.svg +4 -4
- package/assets/svg/pay/blik.svg +12 -12
- package/assets/svg/pay/boleto.svg +39 -39
- package/assets/svg/pay/brazil_bank.svg +27 -27
- package/assets/svg/pay/card.svg +4 -4
- package/assets/svg/pay/carga_virtual.svg +30 -30
- package/assets/svg/pay/cash.svg +6 -6
- package/assets/svg/pay/cashtocode.svg +6 -6
- package/assets/svg/pay/codi.svg +10 -10
- package/assets/svg/pay/comepay.svg +41 -41
- package/assets/svg/pay/cup.svg +6 -6
- package/assets/svg/pay/cup_bank.svg +10 -10
- package/assets/svg/pay/cup_p2p.svg +9 -9
- package/assets/svg/pay/deposit_express.svg +8 -8
- package/assets/svg/pay/direct_banking_europe.svg +8 -8
- package/assets/svg/pay/dotpay.svg +6 -6
- package/assets/svg/pay/ecopayz.svg +7 -7
- package/assets/svg/pay/eps.svg +6 -6
- package/assets/svg/pay/ethereum.svg +9 -9
- package/assets/svg/pay/g2a.svg +7 -7
- package/assets/svg/pay/giropay.svg +5 -5
- package/assets/svg/pay/gmmoney.svg +4 -4
- package/assets/svg/pay/googlepay.svg +7 -7
- package/assets/svg/pay/ideal.svg +7 -7
- package/assets/svg/pay/indonesia_bank.svg +4 -4
- package/assets/svg/pay/jeton.svg +4 -4
- package/assets/svg/pay/kassa24.svg +10 -10
- package/assets/svg/pay/link.svg +14 -14
- package/assets/svg/pay/local_card_mexico.svg +16 -16
- package/assets/svg/pay/loterica.svg +7 -7
- package/assets/svg/pay/malaysia_bank.svg +16 -16
- package/assets/svg/pay/mbway.svg +6 -6
- package/assets/svg/pay/megafon.svg +5 -5
- package/assets/svg/pay/mercado_pago.svg +9 -9
- package/assets/svg/pay/mexico_bank.svg +14 -14
- package/assets/svg/pay/mirpay.svg +4 -4
- package/assets/svg/pay/momopay.svg +4 -4
- package/assets/svg/pay/moneta.svg +5 -5
- package/assets/svg/pay/mts.svg +4 -4
- package/assets/svg/pay/multibanco.svg +6 -6
- package/assets/svg/pay/neosurf.svg +4 -4
- package/assets/svg/pay/neteller.svg +4 -4
- package/assets/svg/pay/nupay.svg +4 -4
- package/assets/svg/pay/onecard.svg +6 -6
- package/assets/svg/pay/oxxo.svg +8 -8
- package/assets/svg/pay/pagoefectivo.svg +4 -4
- package/assets/svg/pay/pagoexpress.svg +5 -5
- package/assets/svg/pay/pagofacil.svg +5 -5
- package/assets/svg/pay/paypal.svg +7 -7
- package/assets/svg/pay/paysafecard.svg +5 -5
- package/assets/svg/pay/philippines_bank.svg +12 -12
- package/assets/svg/pay/picpay.svg +4 -4
- package/assets/svg/pay/pix.svg +6 -6
- package/assets/svg/pay/polish_bank.svg +4 -4
- package/assets/svg/pay/promptpay.svg +4 -4
- package/assets/svg/pay/promsviaz.svg +5 -5
- package/assets/svg/pay/przelewy24.svg +6 -6
- package/assets/svg/pay/qiwi.svg +6 -6
- package/assets/svg/pay/rapid.svg +5 -5
- package/assets/svg/pay/rapipago.svg +5 -5
- package/assets/svg/pay/redcompra.svg +4 -4
- package/assets/svg/pay/redpagos.svg +5 -5
- package/assets/svg/pay/sberbank.svg +23 -23
- package/assets/svg/pay/sbp.svg +11 -11
- package/assets/svg/pay/sepa.svg +7 -7
- package/assets/svg/pay/servipag.svg +7 -7
- package/assets/svg/pay/skinify.svg +5 -5
- package/assets/svg/pay/skinpay.svg +4 -4
- package/assets/svg/pay/skinsback.svg +4 -4
- package/assets/svg/pay/skrill.svg +4 -4
- package/assets/svg/pay/sofort.svg +4 -4
- package/assets/svg/pay/spei.svg +8 -8
- package/assets/svg/pay/steam.svg +15 -15
- package/assets/svg/pay/store_mexico.svg +8 -8
- package/assets/svg/pay/tele2.svg +4 -4
- package/assets/svg/pay/tether.svg +4 -4
- package/assets/svg/pay/thailand_bank.svg +10 -10
- package/assets/svg/pay/tinkoff.svg +38 -38
- package/assets/svg/pay/tron.svg +11 -11
- package/assets/svg/pay/trustly.svg +4 -4
- package/assets/svg/pay/vietnam_bank.svg +4 -4
- package/assets/svg/pay/wallester.svg +35 -35
- package/assets/svg/pay/webmoney.svg +4 -4
- package/assets/svg/pay/webpay.svg +5 -5
- package/assets/svg/pay/wechat.svg +5 -5
- package/assets/svg/pay/yandex.svg +5 -5
- package/assets/svg/pay/zen_wallet.svg +5 -5
- package/assets/svg/pci-dss.svg +19 -19
- package/assets/svg/pt.svg +144 -144
- package/assets/svg/ru.svg +16 -16
- package/assets/svg/status-error.svg +5 -5
- package/assets/svg/status-success.svg +4 -4
- package/assets/svg/status-wait-rotate.svg +18 -18
- package/assets/svg/status-wait.svg +11 -11
- package/assets/svg/tr.svg +13 -13
- package/assets/svg/us.svg +13 -13
- package/assets/svg/wait.svg +11 -11
- package/fesm2022/trm-tmpl.mjs +36 -36
- package/fesm2022/trm-tmpl.mjs.map +1 -1
- package/package.json +1 -1
- package/scss/base.scss +12 -12
- package/scss/btn.scss +50 -50
- package/scss/currency.scss +31 -31
- package/scss/datepicker.scss +19 -19
- package/scss/fonts.scss +18 -18
- package/scss/icons.scss +9 -9
- package/scss/images.scss +43 -43
- package/scss/index.scss +12 -12
- package/scss/input.scss +60 -60
- package/scss/mixins.scss +193 -193
- package/scss/skeleton.scss +68 -68
- package/scss/spinner.scss +65 -65
- package/scss/theme.scss +33 -33
- package/scss/utils.scss +14 -14
- package/scss/validation.scss +7 -7
- package/scss/variables.scss +1 -1
package/fesm2022/trm-tmpl.mjs
CHANGED
|
@@ -3667,8 +3667,8 @@ class ScriptLoader {
|
|
|
3667
3667
|
[
|
|
3668
3668
|
'cde_sdk',
|
|
3669
3669
|
this.environment.production ? {
|
|
3670
|
-
src: 'https://
|
|
3671
|
-
hash: 'sha384-
|
|
3670
|
+
src: 'https://sdk.cde.cloud/iframe/sdk-v1.0.4.js',
|
|
3671
|
+
hash: 'sha384-I0qNl4ogKez0CNyBsdmucHGgwLsiou3eq/bwdBq1bJumX22uFs9tQhIASrQFImmA'
|
|
3672
3672
|
} : {
|
|
3673
3673
|
src: 'https://app.cde-cloud.dev/iframe-sdk/sdk.js',
|
|
3674
3674
|
hash: ''
|
|
@@ -3827,13 +3827,13 @@ class TerminalTplComponent {
|
|
|
3827
3827
|
this.unSubscriber.unsubscribe();
|
|
3828
3828
|
}
|
|
3829
3829
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalTplComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3830
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalTplComponent, isStandalone: true, selector: "terminal", host: { listeners: { "document:keydown.arrowDown": "next($event,$event.currentTarget)", "document:keydown.arrowUp": "prev($event,$event.currentTarget)" }, classAttribute: "trm" }, queries: [{ propertyName: "feeTpl", first: true, predicate: FeeTemplateDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "@if (ready$ | async) {\
|
|
3830
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalTplComponent, isStandalone: true, selector: "terminal", host: { listeners: { "document:keydown.arrowDown": "next($event,$event.currentTarget)", "document:keydown.arrowUp": "prev($event,$event.currentTarget)" }, classAttribute: "trm" }, queries: [{ propertyName: "feeTpl", first: true, predicate: FeeTemplateDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "@if (ready$ | async) {\n <div class=\"app__container\">\n <router-outlet></router-outlet>\n </div>\n}\n", styles: [""], dependencies: [{ kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name", "routerOutletData"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "pipe", type: AsyncPipe, name: "async" }] }); }
|
|
3831
3831
|
}
|
|
3832
3832
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalTplComponent, decorators: [{
|
|
3833
3833
|
type: Component,
|
|
3834
3834
|
args: [{ selector: 'terminal', host: {
|
|
3835
3835
|
class: 'trm'
|
|
3836
|
-
}, imports: [RouterOutlet, AsyncPipe], template: "@if (ready$ | async) {\
|
|
3836
|
+
}, imports: [RouterOutlet, AsyncPipe], template: "@if (ready$ | async) {\n <div class=\"app__container\">\n <router-outlet></router-outlet>\n </div>\n}\n" }]
|
|
3837
3837
|
}], propDecorators: { feeTpl: [{
|
|
3838
3838
|
type: ContentChild,
|
|
3839
3839
|
args: [FeeTemplateDirective, { read: TemplateRef, static: false }]
|
|
@@ -4097,7 +4097,7 @@ class TrmSelectComponent {
|
|
|
4097
4097
|
useExisting: forwardRef(() => TrmSelectComponent),
|
|
4098
4098
|
multi: true,
|
|
4099
4099
|
}
|
|
4100
|
-
], queries: [{ propertyName: "labelTeplate", first: true, predicate: TrmSelectLabelTemplateDirective, descendants: true }], ngImport: i0, template: "@if (label) {\r\n <label class=\"trm-label\"\r\n [for]=\"name\"\r\n (click)=\"toggle()\"\r\n > {{ label }} </label>\r\n}\r\n<div class=\"trm-select\"\r\n [class.trm-select--noBordered]=\"!hasBorder\"\r\n [class.trm-select--opened]=\"opened\"\r\n [class.trm-select--disabled]=\"disabled\"\r\n [tabindex]=\"tabIndex\"\r\n (blur)=\"onBlur()\"\r\n [id]=\"name\"\r\n (keydown.enter)=\"toggle()\"\r\n>\r\n @if (labelTpl) {\r\n <div class=\"trm-select-value\"\r\n (click)=\"toggle()\">\r\n @if (selected && selectedItem) {\r\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item: selectedItem}\"></ng-container>\r\n }\r\n @if (!selected) {\r\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\r\n }\r\n <span class=\"trm-select-value__arrow\"\r\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\r\n @if (data === false) {\r\n <div class=\"trm-spinner\"></div>\r\n }\r\n </div>\r\n @if (opened && hasScrollbar) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-scrollbar appearance=\"compact\" class=\"trm-select-list-scrollbar\" appScrollbarSelectHeight>\r\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\r\n </ng-scrollbar>\r\n </ul>\r\n }\r\n @if (opened && !hasScrollbar) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\r\n </ul>\r\n }\r\n <ng-template #listTpl>\r\n @if (searchable) {\r\n <li class=\"trm-select-list__item trm-select-list__search\">\r\n <input class=\"trm-form-field\"\r\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation(); $event.preventDefault();\"\r\n [formControl]=\"searchControl\">\r\n </li>\r\n }\r\n @if (searchable && searchControl.value && list.length === 0) {\r\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\r\n >\r\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\r\n </li>\r\n }\r\n @for (item of list; track getItemValue(item)) {\r\n <li class=\"trm-select-list__item\"\r\n (click)=\"select(item)\"\r\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\r\n [tabindex]=\"tabIndex\"\r\n (blur)=\"onBlur()\">\r\n @if (item) {\r\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item}\"></ng-container>\r\n }\r\n </li>\r\n }\r\n </ng-template>\r\n } @else {\r\n <div class=\"trm-select-value\"\r\n (click)=\"toggle()\"\r\n (keydown.enter)=\"toggle()\">\r\n {{ selectedLabel }}\r\n @if (!selected) {\r\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\r\n }\r\n <span class=\"trm-select-value__arrow\"\r\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\r\n @if (data === false) {\r\n <div class=\"trm-spinner\"></div>\r\n }\r\n </div>\r\n @if (opened) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-scrollbar class=\"gm-select-list-scrollbar\" appScrollbarSelectHeight>\r\n @if (searchable) {\r\n <li class=\"trm-select-list__item trm-select-list__search\">\r\n <input class=\"trm-form-field\"\r\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation();\"\r\n [formControl]=\"searchControl\">\r\n </li>\r\n }\r\n @if (searchable && searchControl.value && list.length === 0) {\r\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\r\n >\r\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\r\n </li>\r\n }\r\n @for (item of list; track getItemValue(item)) {\r\n <li class=\"trm-select-list__item\"\r\n [tabindex]=\"tabIndex\"\r\n (click)=\"select(item)\"\r\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\r\n (blur)=\"onBlur()\">\r\n {{ getItemLabel(item) }}\r\n </li>\r\n }\r\n </ng-scrollbar>\r\n </ul>\r\n }\r\n }\r\n</div>\r\n<ng-content select=\"[app-trm-select-hint]\"></ng-content>\r\n", styles: [":host{display:block;--trm-select-border-color: var(--color-base-200);--trm-select-border-color--hover: var(--color-base-250);--trm-select-border-color--focus: var(--color-primary-500);--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-primary-500);--trm-select-border-color--disabled: var(--color-base-200);--trm-select-bg-color--disabled: var(--color-base-50)}:host.ng-invalid.ng-touched.ng-dirty{--trm-select-border-color: var(--color-red-500);--trm-select-border-color--hover: var(--color-red-500);--trm-select-border-color--focus: transparent;--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-base-350)}:host.constructor-field-inner .trm-select-value{min-height:44px;border-top-width:0;border-right-width:0;border-bottom-width:0;border-color:var(--trm-select-border-color)!important}@media (min-width: 768px){:host.constructor-field-inner .trm-select-value{min-height:48px}}.trm-select{position:relative;background:var(--trm-select-bg-color, white)}.trm-select:hover .trm-select-value{border-color:var(--trm-select-border-color--hover)}.trm-select:focus,.trm-select:active,.trm-select.trm-select--opened{outline:none}.trm-select:focus .trm-select-value,.trm-select:active .trm-select-value,.trm-select.trm-select--opened .trm-select-value{box-shadow:0 0 0 2px var(--trm-select-border-color--focus);outline:none}.trm-select:focus .trm-select-value__arrow,.trm-select:active .trm-select-value__arrow,.trm-select.trm-select--opened .trm-select-value__arrow{background:var(--trm-select-arrow-color--focus)}.trm-select.trm-select--noBordered{background-color:transparent!important}.trm-select.trm-select--noBordered .trm-select-value{border-color:transparent!important;background-color:transparent!important;box-shadow:none!important;min-height:30px}.trm-select.trm-select--disabled{pointer-events:none}.trm-select.trm-select--disabled .trm-select-value{background:var(--trm-select-bg-color--disabled);outline:none;border:1px solid var(--trm-select-border-color--disabled)}.trm-select.trm-select--disabled .trm-select-value__arrow{display:none}.trm-select-placeholder{font-weight:500;font-size:14px;line-height:20px;color:var(--color-base-350)}@media (min-width: 768px){.trm-select-placeholder{font-weight:500;font-size:15px;line-height:22px;color:var(--color-base-350)}}.trm-select-value{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center;border:1px solid var(--trm-select-border-color);border-radius:var(--trm-select-border-radius, 10px);width:100%;box-sizing:border-box;cursor:pointer;position:relative;min-height:46px;padding:0 var(--trm-select-padding-right, 30px) 0 13px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-value{min-height:50px;padding:0 var(--trm-select-padding-right, 30px) 0 15px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-value__arrow{mask-repeat:no-repeat;mask-size:contain;background:var(--trm-select-arrow-color, black);display:inline-block;height:6px;width:10px;position:absolute;right:var(--trm-select-arrow-right, 15px);top:50%;transform:translateY(-50%);transition:transform ease-in-out .2s}.trm-select-value__arrow-top{transform:translateY(-50%) rotate(180deg)}.trm-select-list{position:absolute;inset:auto auto -10px 0;min-width:100%;margin:0;list-style:none;z-index:100;border:1px solid var(--color-base-150);background:#fff;box-shadow:0 4px 18px #0000000d;border-radius:10px;transform:translateY(100%);box-sizing:border-box;padding:6px;overflow:auto}.trm-select-list__item{box-sizing:border-box;width:100%;padding:9px 10px;border-radius:4px;font-weight:500;font-size:15px;line-height:22px;color:#000;display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center}.trm-select-list__item:hover:not(.trm-select-list__search),.trm-select-list__item:focus:not(.trm-select-list__search),.trm-select-list__item:active:not(.trm-select-list__search){cursor:pointer;background:var(--color-base-50);outline:none}.trm-select-list__item input.trm-form-field{--trm-input-border-color: var(--color-base-200);--trm-input-border-color--hover: var(--color-base-250);--trm-input-border-color--focus: var(--color-primary-500);--trm-input-border-color--disabled: var(--color-base-200);--trm-input-bg-color--disabled: var(--color-base-50);-webkit-appearance:none;border:1px solid var(--trm-input-border-color);border-radius:10px;width:100%;box-sizing:border-box;min-height:46px;padding:12px 20px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-list__item input.trm-form-field{min-height:50px;padding:13px 20px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-list__item input.trm-form-field:hover{border-color:var(--trm-input-border-color--hover)}.trm-select-list__item input.trm-form-field:focus,.trm-select-list__item input.trm-form-field:active{box-shadow:0 0 0 2px var(--trm-input-border-color--focus);outline:none}.trm-select-list__item.trm-select-list__search-text{justify-content:center;opacity:.8;padding:20px}.trm-select-list-scrollbar{--scrollbar-padding: 0px}.trm-select .trm-spinner{margin-left:auto}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: ScrollbarSelectHeightDirective, selector: "ng-scrollbar[appScrollbarSelectHeight]" }, { kind: "component", type: NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
4100
|
+
], queries: [{ propertyName: "labelTeplate", first: true, predicate: TrmSelectLabelTemplateDirective, descendants: true }], ngImport: i0, template: "@if (label) {\n <label class=\"trm-label\"\n [for]=\"name\"\n (click)=\"toggle()\"\n > {{ label }} </label>\n}\n<div class=\"trm-select\"\n [class.trm-select--noBordered]=\"!hasBorder\"\n [class.trm-select--opened]=\"opened\"\n [class.trm-select--disabled]=\"disabled\"\n [tabindex]=\"tabIndex\"\n (blur)=\"onBlur()\"\n [id]=\"name\"\n (keydown.enter)=\"toggle()\"\n>\n @if (labelTpl) {\n <div class=\"trm-select-value\"\n (click)=\"toggle()\">\n @if (selected && selectedItem) {\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item: selectedItem}\"></ng-container>\n }\n @if (!selected) {\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\n }\n <span class=\"trm-select-value__arrow\"\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\n @if (data === false) {\n <div class=\"trm-spinner\"></div>\n }\n </div>\n @if (opened && hasScrollbar) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-scrollbar appearance=\"compact\" class=\"trm-select-list-scrollbar\" appScrollbarSelectHeight>\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\n </ng-scrollbar>\n </ul>\n }\n @if (opened && !hasScrollbar) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\n </ul>\n }\n <ng-template #listTpl>\n @if (searchable) {\n <li class=\"trm-select-list__item trm-select-list__search\">\n <input class=\"trm-form-field\"\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation(); $event.preventDefault();\"\n [formControl]=\"searchControl\">\n </li>\n }\n @if (searchable && searchControl.value && list.length === 0) {\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\n >\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\n </li>\n }\n @for (item of list; track getItemValue(item)) {\n <li class=\"trm-select-list__item\"\n (click)=\"select(item)\"\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\n [tabindex]=\"tabIndex\"\n (blur)=\"onBlur()\">\n @if (item) {\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item}\"></ng-container>\n }\n </li>\n }\n </ng-template>\n } @else {\n <div class=\"trm-select-value\"\n (click)=\"toggle()\"\n (keydown.enter)=\"toggle()\">\n {{ selectedLabel }}\n @if (!selected) {\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\n }\n <span class=\"trm-select-value__arrow\"\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\n @if (data === false) {\n <div class=\"trm-spinner\"></div>\n }\n </div>\n @if (opened) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-scrollbar class=\"gm-select-list-scrollbar\" appScrollbarSelectHeight>\n @if (searchable) {\n <li class=\"trm-select-list__item trm-select-list__search\">\n <input class=\"trm-form-field\"\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation();\"\n [formControl]=\"searchControl\">\n </li>\n }\n @if (searchable && searchControl.value && list.length === 0) {\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\n >\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\n </li>\n }\n @for (item of list; track getItemValue(item)) {\n <li class=\"trm-select-list__item\"\n [tabindex]=\"tabIndex\"\n (click)=\"select(item)\"\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\n (blur)=\"onBlur()\">\n {{ getItemLabel(item) }}\n </li>\n }\n </ng-scrollbar>\n </ul>\n }\n }\n</div>\n<ng-content select=\"[app-trm-select-hint]\"></ng-content>\n", styles: [":host{display:block;--trm-select-border-color: var(--color-base-200);--trm-select-border-color--hover: var(--color-base-250);--trm-select-border-color--focus: var(--color-primary-500);--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-primary-500);--trm-select-border-color--disabled: var(--color-base-200);--trm-select-bg-color--disabled: var(--color-base-50)}:host.ng-invalid.ng-touched.ng-dirty{--trm-select-border-color: var(--color-red-500);--trm-select-border-color--hover: var(--color-red-500);--trm-select-border-color--focus: transparent;--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-base-350)}:host.constructor-field-inner .trm-select-value{min-height:44px;border-top-width:0;border-right-width:0;border-bottom-width:0;border-color:var(--trm-select-border-color)!important}@media (min-width: 768px){:host.constructor-field-inner .trm-select-value{min-height:48px}}.trm-select{position:relative;background:var(--trm-select-bg-color, white)}.trm-select:hover .trm-select-value{border-color:var(--trm-select-border-color--hover)}.trm-select:focus,.trm-select:active,.trm-select.trm-select--opened{outline:none}.trm-select:focus .trm-select-value,.trm-select:active .trm-select-value,.trm-select.trm-select--opened .trm-select-value{box-shadow:0 0 0 2px var(--trm-select-border-color--focus);outline:none}.trm-select:focus .trm-select-value__arrow,.trm-select:active .trm-select-value__arrow,.trm-select.trm-select--opened .trm-select-value__arrow{background:var(--trm-select-arrow-color--focus)}.trm-select.trm-select--noBordered{background-color:transparent!important}.trm-select.trm-select--noBordered .trm-select-value{border-color:transparent!important;background-color:transparent!important;box-shadow:none!important;min-height:30px}.trm-select.trm-select--disabled{pointer-events:none}.trm-select.trm-select--disabled .trm-select-value{background:var(--trm-select-bg-color--disabled);outline:none;border:1px solid var(--trm-select-border-color--disabled)}.trm-select.trm-select--disabled .trm-select-value__arrow{display:none}.trm-select-placeholder{font-weight:500;font-size:14px;line-height:20px;color:var(--color-base-350)}@media (min-width: 768px){.trm-select-placeholder{font-weight:500;font-size:15px;line-height:22px;color:var(--color-base-350)}}.trm-select-value{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center;border:1px solid var(--trm-select-border-color);border-radius:var(--trm-select-border-radius, 10px);width:100%;box-sizing:border-box;cursor:pointer;position:relative;min-height:46px;padding:0 var(--trm-select-padding-right, 30px) 0 13px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-value{min-height:50px;padding:0 var(--trm-select-padding-right, 30px) 0 15px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-value__arrow{mask-repeat:no-repeat;mask-size:contain;background:var(--trm-select-arrow-color, black);display:inline-block;height:6px;width:10px;position:absolute;right:var(--trm-select-arrow-right, 15px);top:50%;transform:translateY(-50%);transition:transform ease-in-out .2s}.trm-select-value__arrow-top{transform:translateY(-50%) rotate(180deg)}.trm-select-list{position:absolute;inset:auto auto -10px 0;min-width:100%;margin:0;list-style:none;z-index:100;border:1px solid var(--color-base-150);background:#fff;box-shadow:0 4px 18px #0000000d;border-radius:10px;transform:translateY(100%);box-sizing:border-box;padding:6px;overflow:auto}.trm-select-list__item{box-sizing:border-box;width:100%;padding:9px 10px;border-radius:4px;font-weight:500;font-size:15px;line-height:22px;color:#000;display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center}.trm-select-list__item:hover:not(.trm-select-list__search),.trm-select-list__item:focus:not(.trm-select-list__search),.trm-select-list__item:active:not(.trm-select-list__search){cursor:pointer;background:var(--color-base-50);outline:none}.trm-select-list__item input.trm-form-field{--trm-input-border-color: var(--color-base-200);--trm-input-border-color--hover: var(--color-base-250);--trm-input-border-color--focus: var(--color-primary-500);--trm-input-border-color--disabled: var(--color-base-200);--trm-input-bg-color--disabled: var(--color-base-50);-webkit-appearance:none;border:1px solid var(--trm-input-border-color);border-radius:10px;width:100%;box-sizing:border-box;min-height:46px;padding:12px 20px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-list__item input.trm-form-field{min-height:50px;padding:13px 20px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-list__item input.trm-form-field:hover{border-color:var(--trm-input-border-color--hover)}.trm-select-list__item input.trm-form-field:focus,.trm-select-list__item input.trm-form-field:active{box-shadow:0 0 0 2px var(--trm-input-border-color--focus);outline:none}.trm-select-list__item.trm-select-list__search-text{justify-content:center;opacity:.8;padding:20px}.trm-select-list-scrollbar{--scrollbar-padding: 0px}.trm-select .trm-spinner{margin-left:auto}\n"], dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: ScrollbarSelectHeightDirective, selector: "ng-scrollbar[appScrollbarSelectHeight]" }, { kind: "component", type: NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
4101
4101
|
}
|
|
4102
4102
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TrmSelectComponent, decorators: [{
|
|
4103
4103
|
type: Component,
|
|
@@ -4107,7 +4107,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
4107
4107
|
useExisting: forwardRef(() => TrmSelectComponent),
|
|
4108
4108
|
multi: true,
|
|
4109
4109
|
}
|
|
4110
|
-
], animations: [insertRemoveTrigger], imports: [NgTemplateOutlet, NgClass, ScrollbarSelectHeightDirective, NgScrollbar, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (label) {\r\n <label class=\"trm-label\"\r\n [for]=\"name\"\r\n (click)=\"toggle()\"\r\n > {{ label }} </label>\r\n}\r\n<div class=\"trm-select\"\r\n [class.trm-select--noBordered]=\"!hasBorder\"\r\n [class.trm-select--opened]=\"opened\"\r\n [class.trm-select--disabled]=\"disabled\"\r\n [tabindex]=\"tabIndex\"\r\n (blur)=\"onBlur()\"\r\n [id]=\"name\"\r\n (keydown.enter)=\"toggle()\"\r\n>\r\n @if (labelTpl) {\r\n <div class=\"trm-select-value\"\r\n (click)=\"toggle()\">\r\n @if (selected && selectedItem) {\r\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item: selectedItem}\"></ng-container>\r\n }\r\n @if (!selected) {\r\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\r\n }\r\n <span class=\"trm-select-value__arrow\"\r\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\r\n @if (data === false) {\r\n <div class=\"trm-spinner\"></div>\r\n }\r\n </div>\r\n @if (opened && hasScrollbar) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-scrollbar appearance=\"compact\" class=\"trm-select-list-scrollbar\" appScrollbarSelectHeight>\r\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\r\n </ng-scrollbar>\r\n </ul>\r\n }\r\n @if (opened && !hasScrollbar) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\r\n </ul>\r\n }\r\n <ng-template #listTpl>\r\n @if (searchable) {\r\n <li class=\"trm-select-list__item trm-select-list__search\">\r\n <input class=\"trm-form-field\"\r\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation(); $event.preventDefault();\"\r\n [formControl]=\"searchControl\">\r\n </li>\r\n }\r\n @if (searchable && searchControl.value && list.length === 0) {\r\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\r\n >\r\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\r\n </li>\r\n }\r\n @for (item of list; track getItemValue(item)) {\r\n <li class=\"trm-select-list__item\"\r\n (click)=\"select(item)\"\r\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\r\n [tabindex]=\"tabIndex\"\r\n (blur)=\"onBlur()\">\r\n @if (item) {\r\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item}\"></ng-container>\r\n }\r\n </li>\r\n }\r\n </ng-template>\r\n } @else {\r\n <div class=\"trm-select-value\"\r\n (click)=\"toggle()\"\r\n (keydown.enter)=\"toggle()\">\r\n {{ selectedLabel }}\r\n @if (!selected) {\r\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\r\n }\r\n <span class=\"trm-select-value__arrow\"\r\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\r\n @if (data === false) {\r\n <div class=\"trm-spinner\"></div>\r\n }\r\n </div>\r\n @if (opened) {\r\n <ul class=\"trm-select-list\" @insertRemove>\r\n <ng-scrollbar class=\"gm-select-list-scrollbar\" appScrollbarSelectHeight>\r\n @if (searchable) {\r\n <li class=\"trm-select-list__item trm-select-list__search\">\r\n <input class=\"trm-form-field\"\r\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation();\"\r\n [formControl]=\"searchControl\">\r\n </li>\r\n }\r\n @if (searchable && searchControl.value && list.length === 0) {\r\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\r\n >\r\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\r\n </li>\r\n }\r\n @for (item of list; track getItemValue(item)) {\r\n <li class=\"trm-select-list__item\"\r\n [tabindex]=\"tabIndex\"\r\n (click)=\"select(item)\"\r\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\r\n (blur)=\"onBlur()\">\r\n {{ getItemLabel(item) }}\r\n </li>\r\n }\r\n </ng-scrollbar>\r\n </ul>\r\n }\r\n }\r\n</div>\r\n<ng-content select=\"[app-trm-select-hint]\"></ng-content>\r\n", styles: [":host{display:block;--trm-select-border-color: var(--color-base-200);--trm-select-border-color--hover: var(--color-base-250);--trm-select-border-color--focus: var(--color-primary-500);--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-primary-500);--trm-select-border-color--disabled: var(--color-base-200);--trm-select-bg-color--disabled: var(--color-base-50)}:host.ng-invalid.ng-touched.ng-dirty{--trm-select-border-color: var(--color-red-500);--trm-select-border-color--hover: var(--color-red-500);--trm-select-border-color--focus: transparent;--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-base-350)}:host.constructor-field-inner .trm-select-value{min-height:44px;border-top-width:0;border-right-width:0;border-bottom-width:0;border-color:var(--trm-select-border-color)!important}@media (min-width: 768px){:host.constructor-field-inner .trm-select-value{min-height:48px}}.trm-select{position:relative;background:var(--trm-select-bg-color, white)}.trm-select:hover .trm-select-value{border-color:var(--trm-select-border-color--hover)}.trm-select:focus,.trm-select:active,.trm-select.trm-select--opened{outline:none}.trm-select:focus .trm-select-value,.trm-select:active .trm-select-value,.trm-select.trm-select--opened .trm-select-value{box-shadow:0 0 0 2px var(--trm-select-border-color--focus);outline:none}.trm-select:focus .trm-select-value__arrow,.trm-select:active .trm-select-value__arrow,.trm-select.trm-select--opened .trm-select-value__arrow{background:var(--trm-select-arrow-color--focus)}.trm-select.trm-select--noBordered{background-color:transparent!important}.trm-select.trm-select--noBordered .trm-select-value{border-color:transparent!important;background-color:transparent!important;box-shadow:none!important;min-height:30px}.trm-select.trm-select--disabled{pointer-events:none}.trm-select.trm-select--disabled .trm-select-value{background:var(--trm-select-bg-color--disabled);outline:none;border:1px solid var(--trm-select-border-color--disabled)}.trm-select.trm-select--disabled .trm-select-value__arrow{display:none}.trm-select-placeholder{font-weight:500;font-size:14px;line-height:20px;color:var(--color-base-350)}@media (min-width: 768px){.trm-select-placeholder{font-weight:500;font-size:15px;line-height:22px;color:var(--color-base-350)}}.trm-select-value{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center;border:1px solid var(--trm-select-border-color);border-radius:var(--trm-select-border-radius, 10px);width:100%;box-sizing:border-box;cursor:pointer;position:relative;min-height:46px;padding:0 var(--trm-select-padding-right, 30px) 0 13px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-value{min-height:50px;padding:0 var(--trm-select-padding-right, 30px) 0 15px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-value__arrow{mask-repeat:no-repeat;mask-size:contain;background:var(--trm-select-arrow-color, black);display:inline-block;height:6px;width:10px;position:absolute;right:var(--trm-select-arrow-right, 15px);top:50%;transform:translateY(-50%);transition:transform ease-in-out .2s}.trm-select-value__arrow-top{transform:translateY(-50%) rotate(180deg)}.trm-select-list{position:absolute;inset:auto auto -10px 0;min-width:100%;margin:0;list-style:none;z-index:100;border:1px solid var(--color-base-150);background:#fff;box-shadow:0 4px 18px #0000000d;border-radius:10px;transform:translateY(100%);box-sizing:border-box;padding:6px;overflow:auto}.trm-select-list__item{box-sizing:border-box;width:100%;padding:9px 10px;border-radius:4px;font-weight:500;font-size:15px;line-height:22px;color:#000;display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center}.trm-select-list__item:hover:not(.trm-select-list__search),.trm-select-list__item:focus:not(.trm-select-list__search),.trm-select-list__item:active:not(.trm-select-list__search){cursor:pointer;background:var(--color-base-50);outline:none}.trm-select-list__item input.trm-form-field{--trm-input-border-color: var(--color-base-200);--trm-input-border-color--hover: var(--color-base-250);--trm-input-border-color--focus: var(--color-primary-500);--trm-input-border-color--disabled: var(--color-base-200);--trm-input-bg-color--disabled: var(--color-base-50);-webkit-appearance:none;border:1px solid var(--trm-input-border-color);border-radius:10px;width:100%;box-sizing:border-box;min-height:46px;padding:12px 20px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-list__item input.trm-form-field{min-height:50px;padding:13px 20px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-list__item input.trm-form-field:hover{border-color:var(--trm-input-border-color--hover)}.trm-select-list__item input.trm-form-field:focus,.trm-select-list__item input.trm-form-field:active{box-shadow:0 0 0 2px var(--trm-input-border-color--focus);outline:none}.trm-select-list__item.trm-select-list__search-text{justify-content:center;opacity:.8;padding:20px}.trm-select-list-scrollbar{--scrollbar-padding: 0px}.trm-select .trm-spinner{margin-left:auto}\n"] }]
|
|
4110
|
+
], animations: [insertRemoveTrigger], imports: [NgTemplateOutlet, NgClass, ScrollbarSelectHeightDirective, NgScrollbar, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (label) {\n <label class=\"trm-label\"\n [for]=\"name\"\n (click)=\"toggle()\"\n > {{ label }} </label>\n}\n<div class=\"trm-select\"\n [class.trm-select--noBordered]=\"!hasBorder\"\n [class.trm-select--opened]=\"opened\"\n [class.trm-select--disabled]=\"disabled\"\n [tabindex]=\"tabIndex\"\n (blur)=\"onBlur()\"\n [id]=\"name\"\n (keydown.enter)=\"toggle()\"\n>\n @if (labelTpl) {\n <div class=\"trm-select-value\"\n (click)=\"toggle()\">\n @if (selected && selectedItem) {\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item: selectedItem}\"></ng-container>\n }\n @if (!selected) {\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\n }\n <span class=\"trm-select-value__arrow\"\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\n @if (data === false) {\n <div class=\"trm-spinner\"></div>\n }\n </div>\n @if (opened && hasScrollbar) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-scrollbar appearance=\"compact\" class=\"trm-select-list-scrollbar\" appScrollbarSelectHeight>\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\n </ng-scrollbar>\n </ul>\n }\n @if (opened && !hasScrollbar) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-container *ngTemplateOutlet=\"listTpl\"></ng-container>\n </ul>\n }\n <ng-template #listTpl>\n @if (searchable) {\n <li class=\"trm-select-list__item trm-select-list__search\">\n <input class=\"trm-form-field\"\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation(); $event.preventDefault();\"\n [formControl]=\"searchControl\">\n </li>\n }\n @if (searchable && searchControl.value && list.length === 0) {\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\n >\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\n </li>\n }\n @for (item of list; track getItemValue(item)) {\n <li class=\"trm-select-list__item\"\n (click)=\"select(item)\"\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\n [tabindex]=\"tabIndex\"\n (blur)=\"onBlur()\">\n @if (item) {\n <ng-container *ngTemplateOutlet=\"labelTpl; context: {item}\"></ng-container>\n }\n </li>\n }\n </ng-template>\n } @else {\n <div class=\"trm-select-value\"\n (click)=\"toggle()\"\n (keydown.enter)=\"toggle()\">\n {{ selectedLabel }}\n @if (!selected) {\n <span class=\"trm-select-placeholder\">{{ placeholder }}</span>\n }\n <span class=\"trm-select-value__arrow\"\n [ngClass]=\"{'trm-select-value__arrow-top': opened}\"></span>\n @if (data === false) {\n <div class=\"trm-spinner\"></div>\n }\n </div>\n @if (opened) {\n <ul class=\"trm-select-list\" @insertRemove>\n <ng-scrollbar class=\"gm-select-list-scrollbar\" appScrollbarSelectHeight>\n @if (searchable) {\n <li class=\"trm-select-list__item trm-select-list__search\">\n <input class=\"trm-form-field\"\n [placeholder]=\"I18N_KEY.SELECT_SEARCH | trans\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation();\"\n [formControl]=\"searchControl\">\n </li>\n }\n @if (searchable && searchControl.value && list.length === 0) {\n <li class=\"trm-select-list__item trm-select-list__search trm-select-list__search-text\"\n >\n {{ I18N_KEY.SELECT_EMPTY_LIST | trans }}\n </li>\n }\n @for (item of list; track getItemValue(item)) {\n <li class=\"trm-select-list__item\"\n [tabindex]=\"tabIndex\"\n (click)=\"select(item)\"\n (keydown.enter)=\"$event.stopPropagation(); select(item)\"\n (blur)=\"onBlur()\">\n {{ getItemLabel(item) }}\n </li>\n }\n </ng-scrollbar>\n </ul>\n }\n }\n</div>\n<ng-content select=\"[app-trm-select-hint]\"></ng-content>\n", styles: [":host{display:block;--trm-select-border-color: var(--color-base-200);--trm-select-border-color--hover: var(--color-base-250);--trm-select-border-color--focus: var(--color-primary-500);--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-primary-500);--trm-select-border-color--disabled: var(--color-base-200);--trm-select-bg-color--disabled: var(--color-base-50)}:host.ng-invalid.ng-touched.ng-dirty{--trm-select-border-color: var(--color-red-500);--trm-select-border-color--hover: var(--color-red-500);--trm-select-border-color--focus: transparent;--trm-select-arrow-color: var(--color-base-350);--trm-select-arrow-color--focus: var(--color-base-350)}:host.constructor-field-inner .trm-select-value{min-height:44px;border-top-width:0;border-right-width:0;border-bottom-width:0;border-color:var(--trm-select-border-color)!important}@media (min-width: 768px){:host.constructor-field-inner .trm-select-value{min-height:48px}}.trm-select{position:relative;background:var(--trm-select-bg-color, white)}.trm-select:hover .trm-select-value{border-color:var(--trm-select-border-color--hover)}.trm-select:focus,.trm-select:active,.trm-select.trm-select--opened{outline:none}.trm-select:focus .trm-select-value,.trm-select:active .trm-select-value,.trm-select.trm-select--opened .trm-select-value{box-shadow:0 0 0 2px var(--trm-select-border-color--focus);outline:none}.trm-select:focus .trm-select-value__arrow,.trm-select:active .trm-select-value__arrow,.trm-select.trm-select--opened .trm-select-value__arrow{background:var(--trm-select-arrow-color--focus)}.trm-select.trm-select--noBordered{background-color:transparent!important}.trm-select.trm-select--noBordered .trm-select-value{border-color:transparent!important;background-color:transparent!important;box-shadow:none!important;min-height:30px}.trm-select.trm-select--disabled{pointer-events:none}.trm-select.trm-select--disabled .trm-select-value{background:var(--trm-select-bg-color--disabled);outline:none;border:1px solid var(--trm-select-border-color--disabled)}.trm-select.trm-select--disabled .trm-select-value__arrow{display:none}.trm-select-placeholder{font-weight:500;font-size:14px;line-height:20px;color:var(--color-base-350)}@media (min-width: 768px){.trm-select-placeholder{font-weight:500;font-size:15px;line-height:22px;color:var(--color-base-350)}}.trm-select-value{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center;border:1px solid var(--trm-select-border-color);border-radius:var(--trm-select-border-radius, 10px);width:100%;box-sizing:border-box;cursor:pointer;position:relative;min-height:46px;padding:0 var(--trm-select-padding-right, 30px) 0 13px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-value{min-height:50px;padding:0 var(--trm-select-padding-right, 30px) 0 15px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-value__arrow{mask-repeat:no-repeat;mask-size:contain;background:var(--trm-select-arrow-color, black);display:inline-block;height:6px;width:10px;position:absolute;right:var(--trm-select-arrow-right, 15px);top:50%;transform:translateY(-50%);transition:transform ease-in-out .2s}.trm-select-value__arrow-top{transform:translateY(-50%) rotate(180deg)}.trm-select-list{position:absolute;inset:auto auto -10px 0;min-width:100%;margin:0;list-style:none;z-index:100;border:1px solid var(--color-base-150);background:#fff;box-shadow:0 4px 18px #0000000d;border-radius:10px;transform:translateY(100%);box-sizing:border-box;padding:6px;overflow:auto}.trm-select-list__item{box-sizing:border-box;width:100%;padding:9px 10px;border-radius:4px;font-weight:500;font-size:15px;line-height:22px;color:#000;display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:center}.trm-select-list__item:hover:not(.trm-select-list__search),.trm-select-list__item:focus:not(.trm-select-list__search),.trm-select-list__item:active:not(.trm-select-list__search){cursor:pointer;background:var(--color-base-50);outline:none}.trm-select-list__item input.trm-form-field{--trm-input-border-color: var(--color-base-200);--trm-input-border-color--hover: var(--color-base-250);--trm-input-border-color--focus: var(--color-primary-500);--trm-input-border-color--disabled: var(--color-base-200);--trm-input-bg-color--disabled: var(--color-base-50);-webkit-appearance:none;border:1px solid var(--trm-input-border-color);border-radius:10px;width:100%;box-sizing:border-box;min-height:46px;padding:12px 20px;font-weight:500;font-size:14px;line-height:20px;color:#000}@media (min-width: 768px){.trm-select-list__item input.trm-form-field{min-height:50px;padding:13px 20px;font-weight:500;font-size:15px;line-height:22px;color:#000}}.trm-select-list__item input.trm-form-field:hover{border-color:var(--trm-input-border-color--hover)}.trm-select-list__item input.trm-form-field:focus,.trm-select-list__item input.trm-form-field:active{box-shadow:0 0 0 2px var(--trm-input-border-color--focus);outline:none}.trm-select-list__item.trm-select-list__search-text{justify-content:center;opacity:.8;padding:20px}.trm-select-list-scrollbar{--scrollbar-padding: 0px}.trm-select .trm-spinner{margin-left:auto}\n"] }]
|
|
4111
4111
|
}], ctorParameters: () => [], propDecorators: { label: [{
|
|
4112
4112
|
type: Input
|
|
4113
4113
|
}], hasBorder: [{
|
|
@@ -4169,11 +4169,11 @@ class TerminalLangSwitcherComponent {
|
|
|
4169
4169
|
this.unSubscriber.unsubscribe();
|
|
4170
4170
|
}
|
|
4171
4171
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalLangSwitcherComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4172
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalLangSwitcherComponent, isStandalone: true, selector: "app-terminal-lang-switcher", inputs: { loading: "loading", tabIndex: "tabIndex" }, outputs: { langChange: "langChange" }, ngImport: i0, template: "@if (!loading) {\
|
|
4172
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalLangSwitcherComponent, isStandalone: true, selector: "app-terminal-lang-switcher", inputs: { loading: "loading", tabIndex: "tabIndex" }, outputs: { langChange: "langChange" }, ngImport: i0, template: "@if (!loading) {\n <app-trm-select class=\"lang-switcher\"\n [hasBorder]=\"false\"\n [searchable]=\"false\"\n [hasScrollbar]=\"false\"\n [data]=\"langs\"\n [ngModel]=\"lang\"\n [tabIndex]=\"tabIndex\"\n (ngModelChange)=\"changeLang($event)\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"fi\" [ngClass]=\"'fi-' + translation_keys[item].code\"></span>\n <span> {{translation_keys[item].name | translate}}</span>\n </ng-template>\n </app-trm-select>\n} @else {\n <gm-skeleton [count]=\"1\" [size]=\"30\"></gm-skeleton>\n}\n", styles: [":host{display:block}@media (min-width: 768px){:host{min-width:108px}}.lang-switcher{--trm-select-padding-right: 20px;--trm-select-arrow-right: 0;width:100%}.fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.fi~span{display:none}@media (min-width: 768px){.fi~span{display:inline}}.trm-skeleton{min-width:70px}.trm-skeleton .loader,.trm-skeleton .skeleton-loader{height:30px}\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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
4173
4173
|
}
|
|
4174
4174
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalLangSwitcherComponent, decorators: [{
|
|
4175
4175
|
type: Component,
|
|
4176
|
-
args: [{ selector: 'app-terminal-lang-switcher', changeDetection: ChangeDetectionStrategy.OnPush, imports: [TrmSelectComponent, FormsModule, TrmSelectLabelTemplateDirective, NgClass, TranslateModule, GmSkeletonComponent], template: "@if (!loading) {\
|
|
4176
|
+
args: [{ selector: 'app-terminal-lang-switcher', changeDetection: ChangeDetectionStrategy.OnPush, imports: [TrmSelectComponent, FormsModule, TrmSelectLabelTemplateDirective, NgClass, TranslateModule, GmSkeletonComponent], template: "@if (!loading) {\n <app-trm-select class=\"lang-switcher\"\n [hasBorder]=\"false\"\n [searchable]=\"false\"\n [hasScrollbar]=\"false\"\n [data]=\"langs\"\n [ngModel]=\"lang\"\n [tabIndex]=\"tabIndex\"\n (ngModelChange)=\"changeLang($event)\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"fi\" [ngClass]=\"'fi-' + translation_keys[item].code\"></span>\n <span> {{translation_keys[item].name | translate}}</span>\n </ng-template>\n </app-trm-select>\n} @else {\n <gm-skeleton [count]=\"1\" [size]=\"30\"></gm-skeleton>\n}\n", styles: [":host{display:block}@media (min-width: 768px){:host{min-width:108px}}.lang-switcher{--trm-select-padding-right: 20px;--trm-select-arrow-right: 0;width:100%}.fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.fi~span{display:none}@media (min-width: 768px){.fi~span{display:inline}}.trm-skeleton{min-width:70px}.trm-skeleton .loader,.trm-skeleton .skeleton-loader{height:30px}\n"] }]
|
|
4177
4177
|
}], ctorParameters: () => [], propDecorators: { loading: [{
|
|
4178
4178
|
type: Input
|
|
4179
4179
|
}], langChange: [{
|
|
@@ -4210,11 +4210,11 @@ class TerminalLayoutTplComponent {
|
|
|
4210
4210
|
this.unSubscriber.unsubscribe();
|
|
4211
4211
|
}
|
|
4212
4212
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalLayoutTplComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4213
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalLayoutTplComponent, isStandalone: true, selector: "app-terminal-layout-tpl", inputs: { projectName: "projectName", description: "description", loading: "loading" }, ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\
|
|
4213
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalLayoutTplComponent, isStandalone: true, selector: "app-terminal-layout-tpl", inputs: { projectName: "projectName", description: "description", loading: "loading" }, ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\n <div class=\"terminal-layout\">\n <section class=\"terminal\">\n <div class=\"terminal__content\">\n <header class=\"terminal__header\">\n <i class=\"terminal__header-logo\"\n [class]=\"logoClass\"></i>\n <div class=\"terminal__header-lang\">\n @if (hasChoice) {\n <app-terminal-lang-switcher\n [loading]=\"loading\"\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\n }\n </div>\n </header>\n <div class=\"terminal__form\">\n <ng-content selector=\"[terminal-layout-status]\"></ng-content>\n <ng-content selector=\"[terminal-layout-form]\"></ng-content>\n @if (loading) {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n }\n </div>\n </div>\n </section>\n <footer class=\"terminal-footer\">\n <i class=\"terminal-footer__logo\"></i>\n <p class=\"terminal-footer__txt\">\n {{footerText}}\n </p>\n </footer>\n </div>\n</ng-scrollbar>\n", styles: [":host{display:flex;flex-direction:column;height:100vh;box-sizing:border-box}.terminal{box-sizing:border-box;width:100%;max-width:528px;min-width:320px;padding:0 10px}.terminal-layout{min-height:100vh;padding:42px 0;display:flex;flex-direction:column;gap:42px;justify-content:flex-start;align-items:center}.terminal-footer{flex:auto 1 0;display:flex;flex-direction:column;gap:24px;justify-content:flex-end;align-items:center}.terminal-footer__txt{font-weight:400;font-size:14px;line-height:18px;color:var(--color-base-350);margin:0}.terminal__content{box-sizing:border-box;margin:auto;padding:20px;width:100%;background:#fff;border-radius:16px;min-height:300px;display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}@media (min-width: 768px){.terminal__content{padding:32px}}.terminal__header{display:flex;flex-direction:row;gap:0;justify-content:flex-start;align-items:center}@media (min-width: 768px){.terminal__header-logo{width:143px;height:30px}}.terminal__header-lang{margin-left:auto}.terminal__form{display:flex;flex-direction:column;gap:24px;justify-content:flex-start;align-items:stretch;width:100%;margin:auto}.terminal__status{margin-top:8px}.terminal .trm-skeleton-group{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.terminal .trm-skeleton-group__form{gap:20px}.terminal .trm-skeleton-group__form .loader,.terminal .trm-skeleton-group__form .skeleton-loader{height:80px}.terminal .trm-skeleton-group__header .loader,.terminal .trm-skeleton-group__header .skeleton-loader{height:120px}.terminal .trm-skeleton-group__actions{gap:10px}.terminal .trm-skeleton-group__actions .loader,.terminal .trm-skeleton-group__actions .skeleton-loader{height:48px}\n"], dependencies: [{ kind: "component", type: NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "component", type: TerminalLangSwitcherComponent, selector: "app-terminal-lang-switcher", inputs: ["loading", "tabIndex"], outputs: ["langChange"] }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }] }); }
|
|
4214
4214
|
}
|
|
4215
4215
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalLayoutTplComponent, decorators: [{
|
|
4216
4216
|
type: Component,
|
|
4217
|
-
args: [{ selector: 'app-terminal-layout-tpl', imports: [NgScrollbar, TerminalLangSwitcherComponent, GmSkeletonComponent], template: "<ng-scrollbar appearance=\"compact\">\
|
|
4217
|
+
args: [{ selector: 'app-terminal-layout-tpl', imports: [NgScrollbar, TerminalLangSwitcherComponent, GmSkeletonComponent], template: "<ng-scrollbar appearance=\"compact\">\n <div class=\"terminal-layout\">\n <section class=\"terminal\">\n <div class=\"terminal__content\">\n <header class=\"terminal__header\">\n <i class=\"terminal__header-logo\"\n [class]=\"logoClass\"></i>\n <div class=\"terminal__header-lang\">\n @if (hasChoice) {\n <app-terminal-lang-switcher\n [loading]=\"loading\"\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\n }\n </div>\n </header>\n <div class=\"terminal__form\">\n <ng-content selector=\"[terminal-layout-status]\"></ng-content>\n <ng-content selector=\"[terminal-layout-form]\"></ng-content>\n @if (loading) {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n }\n </div>\n </div>\n </section>\n <footer class=\"terminal-footer\">\n <i class=\"terminal-footer__logo\"></i>\n <p class=\"terminal-footer__txt\">\n {{footerText}}\n </p>\n </footer>\n </div>\n</ng-scrollbar>\n", styles: [":host{display:flex;flex-direction:column;height:100vh;box-sizing:border-box}.terminal{box-sizing:border-box;width:100%;max-width:528px;min-width:320px;padding:0 10px}.terminal-layout{min-height:100vh;padding:42px 0;display:flex;flex-direction:column;gap:42px;justify-content:flex-start;align-items:center}.terminal-footer{flex:auto 1 0;display:flex;flex-direction:column;gap:24px;justify-content:flex-end;align-items:center}.terminal-footer__txt{font-weight:400;font-size:14px;line-height:18px;color:var(--color-base-350);margin:0}.terminal__content{box-sizing:border-box;margin:auto;padding:20px;width:100%;background:#fff;border-radius:16px;min-height:300px;display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}@media (min-width: 768px){.terminal__content{padding:32px}}.terminal__header{display:flex;flex-direction:row;gap:0;justify-content:flex-start;align-items:center}@media (min-width: 768px){.terminal__header-logo{width:143px;height:30px}}.terminal__header-lang{margin-left:auto}.terminal__form{display:flex;flex-direction:column;gap:24px;justify-content:flex-start;align-items:stretch;width:100%;margin:auto}.terminal__status{margin-top:8px}.terminal .trm-skeleton-group{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.terminal .trm-skeleton-group__form{gap:20px}.terminal .trm-skeleton-group__form .loader,.terminal .trm-skeleton-group__form .skeleton-loader{height:80px}.terminal .trm-skeleton-group__header .loader,.terminal .trm-skeleton-group__header .skeleton-loader{height:120px}.terminal .trm-skeleton-group__actions{gap:10px}.terminal .trm-skeleton-group__actions .loader,.terminal .trm-skeleton-group__actions .skeleton-loader{height:48px}\n"] }]
|
|
4218
4218
|
}], ctorParameters: () => [], propDecorators: { projectName: [{
|
|
4219
4219
|
type: Input
|
|
4220
4220
|
}], description: [{
|
|
@@ -4255,11 +4255,11 @@ class ConstructorStatusComponent {
|
|
|
4255
4255
|
return this.versionSrv.supportEmail;
|
|
4256
4256
|
}
|
|
4257
4257
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4258
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: ConstructorStatusComponent, isStandalone: true, selector: "app-constructor-status", inputs: { failed: "failed", inProgress: "inProgress", animation: "animation", message: "message", failTitle: "failTitle", progressTitle: "progressTitle", successTitle: "successTitle", tabIndex: "tabIndex", backUrl: "backUrl", backUrlTitle: "backUrlTitle", hasSupportHint: "hasSupportHint" }, ngImport: i0, template: "<div class=\"c-status\">\
|
|
4258
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: ConstructorStatusComponent, isStandalone: true, selector: "app-constructor-status", inputs: { failed: "failed", inProgress: "inProgress", animation: "animation", message: "message", failTitle: "failTitle", progressTitle: "progressTitle", successTitle: "successTitle", tabIndex: "tabIndex", backUrl: "backUrl", backUrlTitle: "backUrlTitle", hasSupportHint: "hasSupportHint" }, ngImport: i0, template: "<div class=\"c-status\">\n <div class=\"c-status__content\"\n [class.c-status--failed]=\"failed\"\n [class.c-status--progress]=\"inProgress\"\n [class.c-status--live]=\"animation\"\n >\n <i class=\"c-status__img\"></i>\n <h5 class=\"c-status__title\">\n @if (inProgress) {\n {{ progressTitle || (I18N_KEY.PROGRESS_TITLE | trans) }}\n } @else {\n @if (failed) {\n {{ failTitle || (I18N_KEY.TERMINAL_SESSION_BREAK | trans) }}\n }\n @if (!failed) {\n {{ successTitle || (I18N_KEY.TERMINAL_SESSION_SUCCESS | trans) }}\n }\n }\n </h5>\n <div class=\"c-status__msg\" [innerHTML]=\"message\"> {{ message }}</div>\n @if (hasSupportHint) {\n <div class=\"c-status__hint\">\n {{ I18N_KEY.TERMINAL_SESSION_SUPPORT | trans }}:\n @if (supportEmail) {\n <a [href]=\"'mailto:' + supportEmail\"> {{ supportEmail }} </a>\n }\n </div>\n }\n </div>\n @if (!!backUrl) {\n <div class=\"c-status__actions\">\n <a class=\"trm-button trm-button--primary\"\n [tabindex]=\"tabIndex\"\n [href]=\"backUrl | sanitize: SecurityContext.URL\"> {{ backUrlTitle || (I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans) }}</a>\n <div class=\"c-status__hint c-status__hint-button\">\n <ng-content constructor-status-button-hint></ng-content>\n </div>\n </div>\n }\n</div>\n", styles: [":host{display:block}.c-status{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.c-status__content{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:stretch}.c-status--progress.c-status--live~.c-status__actions{display:none}.c-status__img{flex:none;margin-bottom:10px;align-self:center;border:0}.c-status__title{text-align:center;align-self:center}.c-status__msg{align-self:center;white-space:normal;overflow:hidden;max-width:100%;text-overflow:ellipsis}.c-status__msg,.c-status__hint{text-align:center;font-weight:400;font-size:15px;line-height:22px;color:var(--color-base-350)}.c-status__hint-button{font-size:14px}.c-status__actions{display:flex;flex-direction:column;gap:4px;justify-content:stretch;align-items:stretch}.c-status__actions .trm-button{color:#fff!important}\n"], dependencies: [{ kind: "pipe", type: SanitizerPipe, name: "sanitize" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
4259
4259
|
}
|
|
4260
4260
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorStatusComponent, decorators: [{
|
|
4261
4261
|
type: Component,
|
|
4262
|
-
args: [{ selector: 'app-constructor-status', changeDetection: ChangeDetectionStrategy.OnPush, imports: [SanitizerPipe, TranslateByKeyPipe], template: "<div class=\"c-status\">\
|
|
4262
|
+
args: [{ selector: 'app-constructor-status', changeDetection: ChangeDetectionStrategy.OnPush, imports: [SanitizerPipe, TranslateByKeyPipe], template: "<div class=\"c-status\">\n <div class=\"c-status__content\"\n [class.c-status--failed]=\"failed\"\n [class.c-status--progress]=\"inProgress\"\n [class.c-status--live]=\"animation\"\n >\n <i class=\"c-status__img\"></i>\n <h5 class=\"c-status__title\">\n @if (inProgress) {\n {{ progressTitle || (I18N_KEY.PROGRESS_TITLE | trans) }}\n } @else {\n @if (failed) {\n {{ failTitle || (I18N_KEY.TERMINAL_SESSION_BREAK | trans) }}\n }\n @if (!failed) {\n {{ successTitle || (I18N_KEY.TERMINAL_SESSION_SUCCESS | trans) }}\n }\n }\n </h5>\n <div class=\"c-status__msg\" [innerHTML]=\"message\"> {{ message }}</div>\n @if (hasSupportHint) {\n <div class=\"c-status__hint\">\n {{ I18N_KEY.TERMINAL_SESSION_SUPPORT | trans }}:\n @if (supportEmail) {\n <a [href]=\"'mailto:' + supportEmail\"> {{ supportEmail }} </a>\n }\n </div>\n }\n </div>\n @if (!!backUrl) {\n <div class=\"c-status__actions\">\n <a class=\"trm-button trm-button--primary\"\n [tabindex]=\"tabIndex\"\n [href]=\"backUrl | sanitize: SecurityContext.URL\"> {{ backUrlTitle || (I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans) }}</a>\n <div class=\"c-status__hint c-status__hint-button\">\n <ng-content constructor-status-button-hint></ng-content>\n </div>\n </div>\n }\n</div>\n", styles: [":host{display:block}.c-status{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.c-status__content{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:stretch}.c-status--progress.c-status--live~.c-status__actions{display:none}.c-status__img{flex:none;margin-bottom:10px;align-self:center;border:0}.c-status__title{text-align:center;align-self:center}.c-status__msg{align-self:center;white-space:normal;overflow:hidden;max-width:100%;text-overflow:ellipsis}.c-status__msg,.c-status__hint{text-align:center;font-weight:400;font-size:15px;line-height:22px;color:var(--color-base-350)}.c-status__hint-button{font-size:14px}.c-status__actions{display:flex;flex-direction:column;gap:4px;justify-content:stretch;align-items:stretch}.c-status__actions .trm-button{color:#fff!important}\n"] }]
|
|
4263
4263
|
}], propDecorators: { failed: [{
|
|
4264
4264
|
type: Input
|
|
4265
4265
|
}], inProgress: [{
|
|
@@ -4354,13 +4354,13 @@ class TrmAmountComponent {
|
|
|
4354
4354
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TrmAmountComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4355
4355
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TrmAmountComponent, isStandalone: true, selector: "trm-amount", inputs: { value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, code: { classPropertyName: "code", publicName: "code", isSignal: true, isRequired: false, transformFunction: null } }, providers: [
|
|
4356
4356
|
CurrencyPipe
|
|
4357
|
-
], ngImport: i0, template: "<span class=\"trm-amount\">\
|
|
4357
|
+
], ngImport: i0, template: "<span class=\"trm-amount\">\n <span class=\"trm-amount__value\">\n <span class=\"trm-amount__int\">{{ amountSplitted().int }}</span>\n @if (amountSplitted().fract) {\n <span class=\"trm-amount__fract\">{{ separator }}{{ amountSplitted().fract }}</span>\n }\n </span>\n <span class=\"trm-currency\">{{ resultSymbol() }}</span>\n</span>\n", styles: [""], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
4358
4358
|
}
|
|
4359
4359
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TrmAmountComponent, decorators: [{
|
|
4360
4360
|
type: Component,
|
|
4361
4361
|
args: [{ selector: 'trm-amount', standalone: true, imports: [], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
4362
4362
|
CurrencyPipe
|
|
4363
|
-
], template: "<span class=\"trm-amount\">\
|
|
4363
|
+
], template: "<span class=\"trm-amount\">\n <span class=\"trm-amount__value\">\n <span class=\"trm-amount__int\">{{ amountSplitted().int }}</span>\n @if (amountSplitted().fract) {\n <span class=\"trm-amount__fract\">{{ separator }}{{ amountSplitted().fract }}</span>\n }\n </span>\n <span class=\"trm-currency\">{{ resultSymbol() }}</span>\n</span>\n" }]
|
|
4364
4364
|
}] });
|
|
4365
4365
|
|
|
4366
4366
|
const components = [
|
|
@@ -4992,7 +4992,7 @@ class ConstructorFieldIframeComponent {
|
|
|
4992
4992
|
multi: true,
|
|
4993
4993
|
},
|
|
4994
4994
|
CardSdkService,
|
|
4995
|
-
], hostDirectives: [{ directive: IframeValidatorDirectiveDirective }], ngImport: i0, template: "@if (!status) {\
|
|
4995
|
+
], hostDirectives: [{ directive: IframeValidatorDirectiveDirective }], ngImport: i0, template: "@if (!status) {\n <div\n class=\"iframe-container\"\n [id]=\"ID_CDE_CONTAINER\"\n [class.iframe-container--ready]=\"viewReady\"\n ></div>\n} @else if (!loading) {\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\n}\n\n@if (loading) {\n <div class=\"trm-skeleton-fields\">\n @for (i of [1,2]; track i) {\n <div class=\"trm-skeleton-field\">\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\n </div>\n }\n </div>\n}\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 }); }
|
|
4996
4996
|
}
|
|
4997
4997
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorFieldIframeComponent, decorators: [{
|
|
4998
4998
|
type: Component,
|
|
@@ -5007,7 +5007,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
5007
5007
|
{
|
|
5008
5008
|
directive: IframeValidatorDirectiveDirective,
|
|
5009
5009
|
},
|
|
5010
|
-
], template: "@if (!status) {\
|
|
5010
|
+
], template: "@if (!status) {\n <div\n class=\"iframe-container\"\n [id]=\"ID_CDE_CONTAINER\"\n [class.iframe-container--ready]=\"viewReady\"\n ></div>\n} @else if (!loading) {\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\n}\n\n@if (loading) {\n <div class=\"trm-skeleton-fields\">\n @for (i of [1,2]; track i) {\n <div class=\"trm-skeleton-field\">\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\n </div>\n }\n </div>\n}\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"] }]
|
|
5011
5011
|
}], propDecorators: { tabIndex: [{
|
|
5012
5012
|
type: Input
|
|
5013
5013
|
}] } });
|
|
@@ -5140,7 +5140,7 @@ class PsSelectComponent {
|
|
|
5140
5140
|
},
|
|
5141
5141
|
MethodTitlePipe,
|
|
5142
5142
|
TranslatePipe
|
|
5143
|
-
], ngImport: i0, template: "<label class=\"trm-label\">\
|
|
5143
|
+
], ngImport: i0, template: "<label class=\"trm-label\">\n {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\n</label>\n<ul class=\"methods\">\n @for (method of popularMethods; track method.id) {\n <li class=\"method\"\n [class.method--selected]=\"selectedType === method.id\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\n (blur)=\"onTouch()\"\n (click)=\"selectMethod(method.id)\"\n >\n <span class=\"method__icon\"\n [ngClass]=\"'ps-icon-'+method.name\"\n ></span>\n <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\n </li>\n }\n @if (searchString || otherMethods.length) {\n <li class=\"methods__other\">\n <app-trm-select [data]=\"otherMethods\"\n idLabel=\"method\"\n (search)=\"search($event)\"\n [tabIndex]=\"tabIndex\"\n (open)=\"onTouch()\"\n [formControl]=\"otherMethodControl\"\n [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\n class=\"c-field-select trm-form-field\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"method__icon\"\n [ngClass]=\"'ps-icon-'+item.name\"></span>\n <span class=\"method__name\"\n [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\n </ng-template>\n </app-trm-select>\n </li>\n }\n</ul>\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\n\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"], dependencies: [{ kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "pipe", type: MethodTitlePipe, name: "method_title" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5144
5144
|
}
|
|
5145
5145
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: PsSelectComponent, decorators: [{
|
|
5146
5146
|
type: Component,
|
|
@@ -5152,7 +5152,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
5152
5152
|
},
|
|
5153
5153
|
MethodTitlePipe,
|
|
5154
5154
|
TranslatePipe
|
|
5155
|
-
], imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe], template: "<label class=\"trm-label\">\
|
|
5155
|
+
], imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe], template: "<label class=\"trm-label\">\n {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\n</label>\n<ul class=\"methods\">\n @for (method of popularMethods; track method.id) {\n <li class=\"method\"\n [class.method--selected]=\"selectedType === method.id\"\n [tabindex]=\"tabIndex\"\n (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\n (blur)=\"onTouch()\"\n (click)=\"selectMethod(method.id)\"\n >\n <span class=\"method__icon\"\n [ngClass]=\"'ps-icon-'+method.name\"\n ></span>\n <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\n </li>\n }\n @if (searchString || otherMethods.length) {\n <li class=\"methods__other\">\n <app-trm-select [data]=\"otherMethods\"\n idLabel=\"method\"\n (search)=\"search($event)\"\n [tabIndex]=\"tabIndex\"\n (open)=\"onTouch()\"\n [formControl]=\"otherMethodControl\"\n [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\n class=\"c-field-select trm-form-field\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"method__icon\"\n [ngClass]=\"'ps-icon-'+item.name\"></span>\n <span class=\"method__name\"\n [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\n </ng-template>\n </app-trm-select>\n </li>\n }\n</ul>\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\n\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"] }]
|
|
5156
5156
|
}], propDecorators: { methods: [{
|
|
5157
5157
|
type: Input
|
|
5158
5158
|
}], tabIndex: [{
|
|
@@ -5212,7 +5212,7 @@ class ConstructorFieldSelectComponent {
|
|
|
5212
5212
|
useExisting: forwardRef(() => ConstructorFieldSelectComponent),
|
|
5213
5213
|
multi: true
|
|
5214
5214
|
}
|
|
5215
|
-
], ngImport: i0, template: "@if (control) {\
|
|
5215
|
+
], ngImport: i0, template: "@if (control) {\n <app-trm-select [data]=\"data\"\n [placeholder]=\"config.placeholder | trans\"\n [label]=\"config.label | trans\"\n [name]=\"config.name\"\n (search)=\"search($event)\"\n (open)=\"onTouch()\"\n [formControl]=\"control\"\n [tabIndex]=\"tabIndex\"\n class=\"c-field-select trm-form-field\"\n ></app-trm-select>\n @if (control.hasError('required') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n @if (control.hasError('error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ apiError | trans }}\n </div>\n }\n\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ control.getError('custom_error') | trans }}\n </div>\n }\n\n}\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$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5216
5216
|
}
|
|
5217
5217
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorFieldSelectComponent, decorators: [{
|
|
5218
5218
|
type: Component,
|
|
@@ -5222,7 +5222,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
5222
5222
|
useExisting: forwardRef(() => ConstructorFieldSelectComponent),
|
|
5223
5223
|
multi: true
|
|
5224
5224
|
}
|
|
5225
|
-
], imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (control) {\
|
|
5225
|
+
], imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (control) {\n <app-trm-select [data]=\"data\"\n [placeholder]=\"config.placeholder | trans\"\n [label]=\"config.label | trans\"\n [name]=\"config.name\"\n (search)=\"search($event)\"\n (open)=\"onTouch()\"\n [formControl]=\"control\"\n [tabIndex]=\"tabIndex\"\n class=\"c-field-select trm-form-field\"\n ></app-trm-select>\n @if (control.hasError('required') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n @if (control.hasError('error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ apiError | trans }}\n </div>\n }\n\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ control.getError('custom_error') | trans }}\n </div>\n }\n\n}\n", styles: [":host{display:block;width:100%}\n"] }]
|
|
5226
5226
|
}], propDecorators: { config: [{
|
|
5227
5227
|
type: Input
|
|
5228
5228
|
}], items: [{
|
|
@@ -5426,7 +5426,7 @@ class ConstructorFieldTextComponent {
|
|
|
5426
5426
|
useExisting: forwardRef(() => ConstructorFieldTextComponent),
|
|
5427
5427
|
multi: true
|
|
5428
5428
|
}
|
|
5429
|
-
], viewQueries: [{ propertyName: "dir", first: true, predicate: NgxMaskDirective, descendants: true }], ngImport: i0, template: "@if (control) {\
|
|
5429
|
+
], viewQueries: [{ propertyName: "dir", first: true, predicate: NgxMaskDirective, descendants: true }], ngImport: i0, template: "@if (control) {\n <label class=\"trm-label\"\n [for]=\"config.name\"\n > {{ config.label | trans }} </label>\n <div class=\"input-wrapper trm-form-field-wrapper c-text\"\n [class.c-text--disabled]=\"disabled\"\n [class.c-text--uppercase]=\"config.uppercase\">\n @if (!matDatepicker) {\n <input\n class=\"trm-form-field trm-input\"\n [class.trm-form-field--disabled]=\"disabled\"\n [placeholder]=\"config.placeholder | trans\"\n (blur)=\"onTouch()\"\n [formControl]=\"control\"\n (input)=\"onInput($event)\"\n (paste)=\"onPaste($event)\"\n [type]=\"type\"\n [name]=\"name\"\n [id]=\"name\"\n [mask]=\"mask\"\n [attr.inputmode]=\"inputmode\"\n [patterns]=\"maskPatterns\"\n [allowNegativeNumbers]=\"false\"\n [thousandSeparator]=\"' '\"\n [decimalMarker]=\"'.'\"\n [validation]=\"config.maskValidation || false\"\n [specialCharacters]=\"specialCharacters\"\n [dropSpecialCharacters]=\"dropSpecialCharacters\"\n [tabindex]=\"tabIndex\"\n />\n } @else {\n <input class=\"trm-form-field trm-input\"\n [matDatepicker]=\"matDatepicker\"\n [formControl]=\"control\"\n [placeholder]=\"config.placeholder | trans\"\n (input)=\"onDateInput($event)\"\n [attr.inputmode]=\"inputmode\"\n (blur)=\"onTouch()\"\n [min]=\"config?.options?.min\"\n [max]=\"config?.options?.max\"\n [tabindex]=\"tabIndex\"\n type=\"text\"\n [name]=\"name\"\n [id]=\"name\"\n />\n }\n <ng-content select=\"[app-c-text-suffix]\"></ng-content>\n </div>\n @if (config.description) {\n <div class=\"c-text__hint\"\n [innerHTML]=\"config.description | trans\"></div>\n }\n <ng-content select=\"[app-c-text-hint]\"></ng-content>\n @if (control.hasError('required') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n @if (control.hasError('email') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_EMAIL | trans }}\n </div>\n }\n @if (control.hasError('min') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_MIN | trans }}\n </div>\n }\n @if (control.hasError('max') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_MAX | trans }}\n </div>\n }\n @if (control.hasError('pattern') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('mask') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\n </div>\n }\n @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\n </div>\n }\n @if (control.hasError('error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ apiError | trans }}\n </div>\n }\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ control.getError('custom_error') | trans }}\n </div>\n }\n}\n", styles: [":host{display:block}.c-text{position:relative}.c-text.c-text--disabled input.trm-form-field{border:1px solid var(--trm-input-border-color--disabled);background:var(--trm-input-bg-color--disabled);pointer-events:none}.c-text.c-text--uppercase input.trm-form-field{text-transform:uppercase}.c-text__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350)}.c-text~.c-text__hint{margin-top:8px}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: NgxMaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions", "instantPrefix"], outputs: ["maskFilled"], exportAs: ["mask", "ngxMask"] }, { kind: "directive", type: InputMaskCorrector, selector: "input[mask]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "directive", type: MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5430
5430
|
}
|
|
5431
5431
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorFieldTextComponent, decorators: [{
|
|
5432
5432
|
type: Component,
|
|
@@ -5436,7 +5436,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
5436
5436
|
useExisting: forwardRef(() => ConstructorFieldTextComponent),
|
|
5437
5437
|
multi: true
|
|
5438
5438
|
}
|
|
5439
|
-
], imports: [FormsModule, NgxMaskDirective, InputMaskCorrector, ReactiveFormsModule, TabIndexFocusDirective, MatDatepickerInput, TranslateByKeyPipe], template: "@if (control) {\
|
|
5439
|
+
], imports: [FormsModule, NgxMaskDirective, InputMaskCorrector, ReactiveFormsModule, TabIndexFocusDirective, MatDatepickerInput, TranslateByKeyPipe], template: "@if (control) {\n <label class=\"trm-label\"\n [for]=\"config.name\"\n > {{ config.label | trans }} </label>\n <div class=\"input-wrapper trm-form-field-wrapper c-text\"\n [class.c-text--disabled]=\"disabled\"\n [class.c-text--uppercase]=\"config.uppercase\">\n @if (!matDatepicker) {\n <input\n class=\"trm-form-field trm-input\"\n [class.trm-form-field--disabled]=\"disabled\"\n [placeholder]=\"config.placeholder | trans\"\n (blur)=\"onTouch()\"\n [formControl]=\"control\"\n (input)=\"onInput($event)\"\n (paste)=\"onPaste($event)\"\n [type]=\"type\"\n [name]=\"name\"\n [id]=\"name\"\n [mask]=\"mask\"\n [attr.inputmode]=\"inputmode\"\n [patterns]=\"maskPatterns\"\n [allowNegativeNumbers]=\"false\"\n [thousandSeparator]=\"' '\"\n [decimalMarker]=\"'.'\"\n [validation]=\"config.maskValidation || false\"\n [specialCharacters]=\"specialCharacters\"\n [dropSpecialCharacters]=\"dropSpecialCharacters\"\n [tabindex]=\"tabIndex\"\n />\n } @else {\n <input class=\"trm-form-field trm-input\"\n [matDatepicker]=\"matDatepicker\"\n [formControl]=\"control\"\n [placeholder]=\"config.placeholder | trans\"\n (input)=\"onDateInput($event)\"\n [attr.inputmode]=\"inputmode\"\n (blur)=\"onTouch()\"\n [min]=\"config?.options?.min\"\n [max]=\"config?.options?.max\"\n [tabindex]=\"tabIndex\"\n type=\"text\"\n [name]=\"name\"\n [id]=\"name\"\n />\n }\n <ng-content select=\"[app-c-text-suffix]\"></ng-content>\n </div>\n @if (config.description) {\n <div class=\"c-text__hint\"\n [innerHTML]=\"config.description | trans\"></div>\n }\n <ng-content select=\"[app-c-text-hint]\"></ng-content>\n @if (control.hasError('required') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n @if (control.hasError('email') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_EMAIL | trans }}\n </div>\n }\n @if (control.hasError('min') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_MIN | trans }}\n </div>\n }\n @if (control.hasError('max') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_MAX | trans }}\n </div>\n }\n @if (control.hasError('pattern') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('mask') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\n </div>\n }\n @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\n </div>\n }\n @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\n </div>\n }\n @if (control.hasError('error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ apiError | trans }}\n </div>\n }\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ control.getError('custom_error') | trans }}\n </div>\n }\n}\n", styles: [":host{display:block}.c-text{position:relative}.c-text.c-text--disabled input.trm-form-field{border:1px solid var(--trm-input-border-color--disabled);background:var(--trm-input-bg-color--disabled);pointer-events:none}.c-text.c-text--uppercase input.trm-form-field{text-transform:uppercase}.c-text__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350)}.c-text~.c-text__hint{margin-top:8px}\n"] }]
|
|
5440
5440
|
}], ctorParameters: () => [], propDecorators: { config: [{
|
|
5441
5441
|
type: Input
|
|
5442
5442
|
}], matDatepicker: [{
|
|
@@ -5460,13 +5460,13 @@ class MethodAmountHintComponent {
|
|
|
5460
5460
|
return this.mainTpl.feeTpl;
|
|
5461
5461
|
}
|
|
5462
5462
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: MethodAmountHintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5463
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: MethodAmountHintComponent, isStandalone: true, selector: "app-method-amount-hint", inputs: { loading: "loading", options: "options" }, host: { properties: { "hidden": "!loading && (!options || (!options.fee && !options.fixedFee && !options.minFixedFee && !options.min && !options.max))" } }, providers: [CurrencyPipe], ngImport: i0, template: "<div class=\"c-method-hint\" @insertRemove>\
|
|
5463
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: MethodAmountHintComponent, isStandalone: true, selector: "app-method-amount-hint", inputs: { loading: "loading", options: "options" }, host: { properties: { "hidden": "!loading && (!options || (!options.fee && !options.fixedFee && !options.minFixedFee && !options.min && !options.max))" } }, providers: [CurrencyPipe], ngImport: i0, template: "<div class=\"c-method-hint\" @insertRemove>\n @if (loading) {\n <span class=\"trm-spinner\" @insertRemove></span>\n }\n @if (options.fee || options.fixedFee) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_FEE | trans) }}\n @if (options.fee) {\n <span class=\"trm-amount\">\n <span class=\"trm-amount__value\">{{ options.fee }}<span class=\"trm-currency\">%</span></span>\n </span>\n }\n @if (options.fixedFee && options.fee) {\n <span> + </span>\n }\n @if (options.fixedFee) {\n <trm-amount [value]=\"options.fixedFee\" [code]=\"options.currency\"></trm-amount>\n }\n @if (options.minFixedFee) {\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<trm-amount [value]=\"options.minFixedFee\" [code]=\"options.currency\"></trm-amount>)\n }\n </div>\n }\n @if (options.min) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\n <trm-amount [value]=\"options.min\" [code]=\"options.currency\"></trm-amount>\n </div>\n }\n @if (options.max) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\n <trm-amount [value]=\"options.max\" [code]=\"options.currency\"></trm-amount>\n </div>\n }\n\n @if (feeTpl) {\n <div *ngTemplateOutlet=\"feeTpl; context: {options}\" @insertRemove></div>\n }\n</div>\n", styles: [":host{display:block;position:relative}.trm-spinner{position:absolute;right:10px}.c-method-hint{position:relative;font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350)}.c-method-hint:first-letter,.c-method-hint>div:first-letter{text-transform:uppercase}\n"], dependencies: [{ kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: TrmAmountComponent, selector: "trm-amount", inputs: ["value", "code"] }], animations: [insertRemoveTrigger] }); }
|
|
5464
5464
|
}
|
|
5465
5465
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: MethodAmountHintComponent, decorators: [{
|
|
5466
5466
|
type: Component,
|
|
5467
5467
|
args: [{ selector: 'app-method-amount-hint', animations: [insertRemoveTrigger], providers: [CurrencyPipe], imports: [TranslateByKeyPipe, NgTemplateOutlet, TrmAmountComponent], host: {
|
|
5468
5468
|
'[hidden]': '!loading && (!options || (!options.fee && !options.fixedFee && !options.minFixedFee && !options.min && !options.max))'
|
|
5469
|
-
}, template: "<div class=\"c-method-hint\" @insertRemove>\
|
|
5469
|
+
}, template: "<div class=\"c-method-hint\" @insertRemove>\n @if (loading) {\n <span class=\"trm-spinner\" @insertRemove></span>\n }\n @if (options.fee || options.fixedFee) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_FEE | trans) }}\n @if (options.fee) {\n <span class=\"trm-amount\">\n <span class=\"trm-amount__value\">{{ options.fee }}<span class=\"trm-currency\">%</span></span>\n </span>\n }\n @if (options.fixedFee && options.fee) {\n <span> + </span>\n }\n @if (options.fixedFee) {\n <trm-amount [value]=\"options.fixedFee\" [code]=\"options.currency\"></trm-amount>\n }\n @if (options.minFixedFee) {\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<trm-amount [value]=\"options.minFixedFee\" [code]=\"options.currency\"></trm-amount>)\n }\n </div>\n }\n @if (options.min) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\n <trm-amount [value]=\"options.min\" [code]=\"options.currency\"></trm-amount>\n </div>\n }\n @if (options.max) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\n <trm-amount [value]=\"options.max\" [code]=\"options.currency\"></trm-amount>\n </div>\n }\n\n @if (feeTpl) {\n <div *ngTemplateOutlet=\"feeTpl; context: {options}\" @insertRemove></div>\n }\n</div>\n", styles: [":host{display:block;position:relative}.trm-spinner{position:absolute;right:10px}.c-method-hint{position:relative;font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350)}.c-method-hint:first-letter,.c-method-hint>div:first-letter{text-transform:uppercase}\n"] }]
|
|
5470
5470
|
}], propDecorators: { loading: [{
|
|
5471
5471
|
type: Input
|
|
5472
5472
|
}], options: [{
|
|
@@ -5523,7 +5523,7 @@ class ConstructorFieldDateComponent {
|
|
|
5523
5523
|
useExisting: forwardRef(() => ConstructorFieldDateComponent),
|
|
5524
5524
|
multi: true
|
|
5525
5525
|
}
|
|
5526
|
-
], ngImport: i0, template: "@if (control) {\
|
|
5526
|
+
], ngImport: i0, template: "@if (control) {\n <app-constructor-field-text\n class=\"c-date__input\"\n [tabIndex]=\"tabIndex\"\n [config]=\"config\"\n [formControl]=\"control\"\n [matDatepicker]=\"picker\">\n <mat-datepicker-toggle [for]=\"picker\"\n app-c-text-suffix\n class=\"date__toggle\"\n [tabIndex]=\"tabIndex\"\n >\n <div class=\"date__toggleIcon\"\n matDatepickerToggleIcon\n app-c-text-suffix></div>\n </mat-datepicker-toggle>\n </app-constructor-field-text>\n\n <mat-datepicker #picker [tabIndex]=\"tabIndex\" [startAt]=\"startCalendarDate\"></mat-datepicker>\n}\n", styles: [":host{display:block}.date__toggle{position:absolute;top:50%;right:-20px;transform:translate(-50%,-50%);flex-shrink:0}.date__toggleIcon{display:block;mask-repeat:no-repeat;mask-size:contain}\n"], dependencies: [{ kind: "component", type: ConstructorFieldTextComponent, selector: "app-constructor-field-text", inputs: ["config", "matDatepicker", "tabIndex"], outputs: ["maskedValueChange"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: MatDatepickerToggleIcon, selector: "[matDatepickerToggleIcon]" }, { kind: "component", type: MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5527
5527
|
}
|
|
5528
5528
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorFieldDateComponent, decorators: [{
|
|
5529
5529
|
type: Component,
|
|
@@ -5533,7 +5533,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
5533
5533
|
useExisting: forwardRef(() => ConstructorFieldDateComponent),
|
|
5534
5534
|
multi: true
|
|
5535
5535
|
}
|
|
5536
|
-
], imports: [ConstructorFieldTextComponent, FormsModule, ReactiveFormsModule, MatDatepickerToggle, MatDatepickerToggleIcon, MatDatepicker], template: "@if (control) {\
|
|
5536
|
+
], imports: [ConstructorFieldTextComponent, FormsModule, ReactiveFormsModule, MatDatepickerToggle, MatDatepickerToggleIcon, MatDatepicker], template: "@if (control) {\n <app-constructor-field-text\n class=\"c-date__input\"\n [tabIndex]=\"tabIndex\"\n [config]=\"config\"\n [formControl]=\"control\"\n [matDatepicker]=\"picker\">\n <mat-datepicker-toggle [for]=\"picker\"\n app-c-text-suffix\n class=\"date__toggle\"\n [tabIndex]=\"tabIndex\"\n >\n <div class=\"date__toggleIcon\"\n matDatepickerToggleIcon\n app-c-text-suffix></div>\n </mat-datepicker-toggle>\n </app-constructor-field-text>\n\n <mat-datepicker #picker [tabIndex]=\"tabIndex\" [startAt]=\"startCalendarDate\"></mat-datepicker>\n}\n", styles: [":host{display:block}.date__toggle{position:absolute;top:50%;right:-20px;transform:translate(-50%,-50%);flex-shrink:0}.date__toggleIcon{display:block;mask-repeat:no-repeat;mask-size:contain}\n"] }]
|
|
5537
5537
|
}], propDecorators: { config: [{
|
|
5538
5538
|
type: Input
|
|
5539
5539
|
}], tabIndex: [{
|
|
@@ -5546,11 +5546,11 @@ class ConstructorPreparationComponent {
|
|
|
5546
5546
|
this.I18N_KEY = I18N_KEY;
|
|
5547
5547
|
}
|
|
5548
5548
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorPreparationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
5549
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: ConstructorPreparationComponent, isStandalone: true, selector: "app-constructor-preparation", inputs: { maskedWallet: "maskedWallet", wallet: "wallet", confirmationText: "confirmationText", methodName: "methodName", currency: "currency", amount: "amount", total: "total" }, providers: [CurrencyPipe], ngImport: i0, template: "<div class=\"confirmation\">\
|
|
5549
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: ConstructorPreparationComponent, isStandalone: true, selector: "app-constructor-preparation", inputs: { maskedWallet: "maskedWallet", wallet: "wallet", confirmationText: "confirmationText", methodName: "methodName", currency: "currency", amount: "amount", total: "total" }, providers: [CurrencyPipe], ngImport: i0, template: "<div class=\"confirmation\">\n <h5> {{ I18N_KEY.CONSTRUCTOR_PREPARATION_HEADER | trans }} </h5>\n <div class=\"confirmation__content\">\n <ul class=\"confirmation__list\">\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}} </div>\n <div class=\"confirmation__value\"> {{methodName | trans}} </div>\n </li>\n\n @if (maskedWallet || wallet) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_WALLET | trans}} </div>\n <div class=\"confirmation__value\"> {{ maskedWallet || wallet}} </div>\n </li>\n }\n\n @if (amount) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT | trans}} </div>\n <div class=\"confirmation__value\">\n <trm-amount [value]=\"amount\" [code]=\"currency\"></trm-amount>\n </div>\n </li>\n }\n\n @if (total) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT_FEE | trans}} </div>\n <div class=\"confirmation__value\">\n <trm-amount [value]=\"total\" [code]=\"currency\"></trm-amount>\n </div>\n </li>\n }\n </ul>\n @if (confirmationText) {\n <p\n class=\"confirmation__text\" [innerHTML]=\"confirmationText\"></p>\n }\n <ng-content selector=\"[app-constructor-preparation-error]\"></ng-content>\n </div>\n</div>\n", styles: [".confirmation{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.confirmation__content{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.confirmation__text{font-weight:600;font-size:15px;line-height:22px;color:var(--color-base-350);margin:0}.confirmation__list{list-style:none;margin:0;padding:0}.confirmation__list__item{border-radius:10px;padding:15px 20px;display:flex;justify-content:space-between}.confirmation__list__item:nth-child(odd){background:#f5f5f5}.confirmation__header{font-weight:400;font-size:15px;line-height:20px;color:var(--color-base-350)}.confirmation__value{font-weight:500;font-size:15px;line-height:20px;color:#000}\n"], dependencies: [{ kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: TrmAmountComponent, selector: "trm-amount", inputs: ["value", "code"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5550
5550
|
}
|
|
5551
5551
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorPreparationComponent, decorators: [{
|
|
5552
5552
|
type: Component,
|
|
5553
|
-
args: [{ selector: 'app-constructor-preparation', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CurrencyPipe], imports: [TranslateByKeyPipe, TrmAmountComponent], template: "<div class=\"confirmation\">\
|
|
5553
|
+
args: [{ selector: 'app-constructor-preparation', changeDetection: ChangeDetectionStrategy.OnPush, providers: [CurrencyPipe], imports: [TranslateByKeyPipe, TrmAmountComponent], template: "<div class=\"confirmation\">\n <h5> {{ I18N_KEY.CONSTRUCTOR_PREPARATION_HEADER | trans }} </h5>\n <div class=\"confirmation__content\">\n <ul class=\"confirmation__list\">\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}} </div>\n <div class=\"confirmation__value\"> {{methodName | trans}} </div>\n </li>\n\n @if (maskedWallet || wallet) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_WALLET | trans}} </div>\n <div class=\"confirmation__value\"> {{ maskedWallet || wallet}} </div>\n </li>\n }\n\n @if (amount) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT | trans}} </div>\n <div class=\"confirmation__value\">\n <trm-amount [value]=\"amount\" [code]=\"currency\"></trm-amount>\n </div>\n </li>\n }\n\n @if (total) {\n <li class=\"confirmation__list__item\">\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT_FEE | trans}} </div>\n <div class=\"confirmation__value\">\n <trm-amount [value]=\"total\" [code]=\"currency\"></trm-amount>\n </div>\n </li>\n }\n </ul>\n @if (confirmationText) {\n <p\n class=\"confirmation__text\" [innerHTML]=\"confirmationText\"></p>\n }\n <ng-content selector=\"[app-constructor-preparation-error]\"></ng-content>\n </div>\n</div>\n", styles: [".confirmation{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.confirmation__content{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.confirmation__text{font-weight:600;font-size:15px;line-height:22px;color:var(--color-base-350);margin:0}.confirmation__list{list-style:none;margin:0;padding:0}.confirmation__list__item{border-radius:10px;padding:15px 20px;display:flex;justify-content:space-between}.confirmation__list__item:nth-child(odd){background:#f5f5f5}.confirmation__header{font-weight:400;font-size:15px;line-height:20px;color:var(--color-base-350)}.confirmation__value{font-weight:500;font-size:15px;line-height:20px;color:#000}\n"] }]
|
|
5554
5554
|
}], propDecorators: { maskedWallet: [{
|
|
5555
5555
|
type: Input
|
|
5556
5556
|
}], wallet: [{
|
|
@@ -5860,14 +5860,14 @@ class ConstructorFormComponent {
|
|
|
5860
5860
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: ConstructorFormComponent, isStandalone: true, selector: "app-constructor-form", inputs: { step: "step", error: "error", response: "response", feeLoading: "feeLoading", feeOptions: "feeOptions", currency: "currency", userCurrency: "userCurrency", loading: "loading", types: "types", canReturnToProject: "canReturnToProject", tabIndex: "tabIndex" }, outputs: { amountChanged: "amountChanged", back: "back", prepare: "prepare", confirm: "confirm", onPaymentChanged: "onPaymentChanged" }, providers: [
|
|
5861
5861
|
ConstructorFormService,
|
|
5862
5862
|
CountryTranslatePipe, CountriesSortPipe
|
|
5863
|
-
], viewQueries: [{ propertyName: "requisites", first: true, predicate: ["paymentRequisites"], descendants: true }, { propertyName: "hintMethod", first: true, predicate: ["hintMethod"], descendants: true }, { propertyName: "sdkList", predicate: CardSdkService, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n @if (!hasCurrencyMethodSelector) {\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n }\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n class=\"constructor-field-inner\"\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:1px;right:1px;flex-shrink:0;min-height:44px}@media (min-width: 768px){.constructor__currency{min-height:48px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1$1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PsSelectComponent, selector: "app-ps-select", inputs: ["methods", "tabIndex"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ConstructorFieldIframeComponent, selector: "app-constructor-field-iframe", inputs: ["tabIndex"] }, { kind: "component", type: ConstructorFieldSelectComponent, selector: "app-constructor-field-select", inputs: ["config", "items", "tabIndex"] }, { kind: "component", type: ConstructorFieldTextComponent, selector: "app-constructor-field-text", inputs: ["config", "matDatepicker", "tabIndex"], outputs: ["maskedValueChange"] }, { kind: "component", type: MethodAmountHintComponent, selector: "app-method-amount-hint", inputs: ["loading", "options"] }, { kind: "component", type: ConstructorFieldDateComponent, selector: "app-constructor-field-date", inputs: ["config", "tabIndex"] }, { kind: "component", type: ConstructorPreparationComponent, selector: "app-constructor-preparation", inputs: ["maskedWallet", "wallet", "confirmationText", "methodName", "currency", "amount", "total"] }, { kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5863
|
+
], viewQueries: [{ propertyName: "requisites", first: true, predicate: ["paymentRequisites"], descendants: true }, { propertyName: "hintMethod", first: true, predicate: ["hintMethod"], descendants: true }, { propertyName: "sdkList", predicate: CardSdkService, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form class=\"constructor\"\n [formGroup]=\"form\"\n (ngSubmit)=\"submit()\"\n >\n @if (loading !== null) {\n @if (step === TERMINAL_STEP.Prepare) {\n <div class=\"constructor__fields\">\n @if (countrySearchString || countriesList.length > 1) {\n <div class=\"constructor__field\">\n <app-trm-select [data]=\"countriesList\"\n @insertRemove\n name=\"country\"\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\n formControlName=\"country\"\n class=\"c-field-select trm-form-field\"\n (search)=\"searchCountry($event)\"\n [tabIndex]=\"tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"fi\"\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\n </ng-template>\n </app-trm-select>\n </div>\n }\n @if (form.country.value) {\n <app-ps-select [methods]=\"methodsList\"\n @insertRemove\n formControlName=\"method\"\n [tabIndex]=\"tabIndex\"\n >\n @if (form.config?.description) {\n <div class=\"constructor__hint text--warn\"\n app-ps-select-hint\n #hintMethod\n @insertRemove\n >\n {{description | trans }}\n </div>\n }\n </app-ps-select>\n\n @if (\n form.method?.hasError('required') &&\n form.method.touched &&\n form.method.dirty\n ) {\n <div class=\"gm-error\" @insertRemove>\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n }\n\n @if (form.ready) {\n <div formGroupName=\"payment\"\n @insertRemove\n #paymentRequisites\n class=\"constructor__fields constructor__fields--reverse\">\n @if (form.method.value && form.amountDynamic) {\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\n }\n @for (field of form.fields; track field.name; let i = $index) {\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\n <div class=\"constructor__hint cde-error\" @insertRemove>\n {{\n form.payment.get(field.name).getError('cde_error')\n | trans\n }}\n </div>\n }\n <app-constructor-field-iframe\n [formControlName]=\"field.name\"\n @insertRemove\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n >\n </app-constructor-field-iframe>\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\n <app-constructor-field-select\n @insertRemove\n [config]=\"field\"\n [items]=\"field?.options?.items\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n ></app-constructor-field-select>\n }\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\n <app-constructor-field-text\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\n <app-constructor-field-text\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\">\n <app-method-amount-hint app-c-text-hint\n class=\"constructor__hint\"\n [loading]=\"feeLoading\"\n [options]=\"feeOptions || field.options\"\n ></app-method-amount-hint>\n @if (!hasCurrencyMethodSelector) {\n <div app-c-text-suffix\n class=\"constructor__currency\"\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\n >\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\n </div>\n }\n </app-constructor-field-text>\n @if (hasCurrencyMethodSelector) {\n <app-trm-select\n @insertRemove\n class=\"constructor-field\"\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\n [formControl]=\"form.currency\"\n [searchable]=\"false\"\n [data]=\"currenciesList\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\n [title]=\"item\"></span>\n {{item}}\n </ng-template>\n </app-trm-select>\n }\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\n <app-constructor-field-date\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\n }\n }\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\n <app-trm-select\n class=\"constructor-field-inner\"\n @insertRemove\n [label]=\"label\"\n [formControl]=\"form.userCurrency\"\n [searchable]=\"false\"\n [data]=\"userCurrenciesList\"\n [tabIndex]=\"tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"trm-icon\"\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\n [title]=\"item\"></span>\n {{item}}\n </ng-template>\n </app-trm-select>\n </ng-template>\n </div>\n } @else {\n <div class=\"trm-skeleton-fields\">\n @for (i of skeletonLength; track $index) {\n <div class=\"trm-skeleton-field\">\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\n </div>\n }\n </div>\n }\n @if (error && !form.methodInfoLoading) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ error | trans }}\n </div>\n }\n </div>\n }\n @if (step === TERMINAL_STEP.Confirmation) {\n <app-constructor-preparation\n @insertRemove\n [currency]=\"response?.currency\"\n [methodName]=\"form.getTypeNameById(response.typeId)\"\n [wallet]=\"response.wallet\"\n [maskedWallet]=\"maskedWallet\"\n [amount]=\"response.amount\"\n [total]=\"response.total\"\n [confirmationText]=\"form.config?.confirmation\"\n >\n @if (error && !form.payment.pending) {\n <div class=\"trm-error\"\n app-constructor-preparation-error\n @insertRemove\n >\n {{ error | trans }}\n </div>\n }\n </app-constructor-preparation>\n }\n <div class=\"constructor__actions\"\n @insertRemove>\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\n type=\"submit\"\n [tabindex]=\"form.fields.length + tabIndex\">\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\n @if (loading) {\n <span class=\"trm-spinner trm-spinner-white\"></span>\n }\n </button>\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\n type=\"button\"\n [tabindex]=\"form.fields.length + tabIndex\"\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\n </div>\n } @else {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n }\n</form>\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:1px;right:1px;flex-shrink:0;min-height:44px}@media (min-width: 768px){.constructor__currency{min-height:48px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1$1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1$1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1$1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1$1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i1$1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "directive", type: TrmSelectLabelTemplateDirective, selector: "[trmSelectLabelTemplate]" }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: PsSelectComponent, selector: "app-ps-select", inputs: ["methods", "tabIndex"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: ConstructorFieldIframeComponent, selector: "app-constructor-field-iframe", inputs: ["tabIndex"] }, { kind: "component", type: ConstructorFieldSelectComponent, selector: "app-constructor-field-select", inputs: ["config", "items", "tabIndex"] }, { kind: "component", type: ConstructorFieldTextComponent, selector: "app-constructor-field-text", inputs: ["config", "matDatepicker", "tabIndex"], outputs: ["maskedValueChange"] }, { kind: "component", type: MethodAmountHintComponent, selector: "app-method-amount-hint", inputs: ["loading", "options"] }, { kind: "component", type: ConstructorFieldDateComponent, selector: "app-constructor-field-date", inputs: ["config", "tabIndex"] }, { kind: "component", type: ConstructorPreparationComponent, selector: "app-constructor-preparation", inputs: ["maskedWallet", "wallet", "confirmationText", "methodName", "currency", "amount", "total"] }, { kind: "directive", type: TabIndexFocusDirective, selector: "[tabindex]" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
5864
5864
|
}
|
|
5865
5865
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ConstructorFormComponent, decorators: [{
|
|
5866
5866
|
type: Component,
|
|
5867
5867
|
args: [{ selector: 'app-constructor-form', changeDetection: ChangeDetectionStrategy.OnPush, animations: [insertRemoveTrigger], providers: [
|
|
5868
5868
|
ConstructorFormService,
|
|
5869
5869
|
CountryTranslatePipe, CountriesSortPipe
|
|
5870
|
-
], imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n @if (!hasCurrencyMethodSelector) {\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n }\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n class=\"constructor-field-inner\"\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:1px;right:1px;flex-shrink:0;min-height:44px}@media (min-width: 768px){.constructor__currency{min-height:48px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
|
|
5870
|
+
], imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\n [formGroup]=\"form\"\n (ngSubmit)=\"submit()\"\n >\n @if (loading !== null) {\n @if (step === TERMINAL_STEP.Prepare) {\n <div class=\"constructor__fields\">\n @if (countrySearchString || countriesList.length > 1) {\n <div class=\"constructor__field\">\n <app-trm-select [data]=\"countriesList\"\n @insertRemove\n name=\"country\"\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\n formControlName=\"country\"\n class=\"c-field-select trm-form-field\"\n (search)=\"searchCountry($event)\"\n [tabIndex]=\"tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"fi\"\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\n </ng-template>\n </app-trm-select>\n </div>\n }\n @if (form.country.value) {\n <app-ps-select [methods]=\"methodsList\"\n @insertRemove\n formControlName=\"method\"\n [tabIndex]=\"tabIndex\"\n >\n @if (form.config?.description) {\n <div class=\"constructor__hint text--warn\"\n app-ps-select-hint\n #hintMethod\n @insertRemove\n >\n {{description | trans }}\n </div>\n }\n </app-ps-select>\n\n @if (\n form.method?.hasError('required') &&\n form.method.touched &&\n form.method.dirty\n ) {\n <div class=\"gm-error\" @insertRemove>\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\n </div>\n }\n }\n\n @if (form.ready) {\n <div formGroupName=\"payment\"\n @insertRemove\n #paymentRequisites\n class=\"constructor__fields constructor__fields--reverse\">\n @if (form.method.value && form.amountDynamic) {\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\n }\n @for (field of form.fields; track field.name; let i = $index) {\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\n <div class=\"constructor__hint cde-error\" @insertRemove>\n {{\n form.payment.get(field.name).getError('cde_error')\n | trans\n }}\n </div>\n }\n <app-constructor-field-iframe\n [formControlName]=\"field.name\"\n @insertRemove\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n >\n </app-constructor-field-iframe>\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\n <app-constructor-field-select\n @insertRemove\n [config]=\"field\"\n [items]=\"field?.options?.items\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n ></app-constructor-field-select>\n }\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\n <app-constructor-field-text\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\n <app-constructor-field-text\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\">\n <app-method-amount-hint app-c-text-hint\n class=\"constructor__hint\"\n [loading]=\"feeLoading\"\n [options]=\"feeOptions || field.options\"\n ></app-method-amount-hint>\n @if (!hasCurrencyMethodSelector) {\n <div app-c-text-suffix\n class=\"constructor__currency\"\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\n >\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\n </div>\n }\n </app-constructor-field-text>\n @if (hasCurrencyMethodSelector) {\n <app-trm-select\n @insertRemove\n class=\"constructor-field\"\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\n [formControl]=\"form.currency\"\n [searchable]=\"false\"\n [data]=\"currenciesList\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\n [title]=\"item\"></span>\n {{item}}\n </ng-template>\n </app-trm-select>\n }\n }\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\n <app-constructor-field-date\n @insertRemove\n [config]=\"field\"\n [formControlName]=\"field.name\"\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\n }\n }\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\n <app-trm-select\n class=\"constructor-field-inner\"\n @insertRemove\n [label]=\"label\"\n [formControl]=\"form.userCurrency\"\n [searchable]=\"false\"\n [data]=\"userCurrenciesList\"\n [tabIndex]=\"tabIndex\"\n >\n <ng-template trmSelectLabelTemplate let-item=\"item\">\n <span class=\"trm-icon\"\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\n [title]=\"item\"></span>\n {{item}}\n </ng-template>\n </app-trm-select>\n </ng-template>\n </div>\n } @else {\n <div class=\"trm-skeleton-fields\">\n @for (i of skeletonLength; track $index) {\n <div class=\"trm-skeleton-field\">\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\n </div>\n }\n </div>\n }\n @if (error && !form.methodInfoLoading) {\n <div class=\"trm-error\"\n @insertRemove\n >\n {{ error | trans }}\n </div>\n }\n </div>\n }\n @if (step === TERMINAL_STEP.Confirmation) {\n <app-constructor-preparation\n @insertRemove\n [currency]=\"response?.currency\"\n [methodName]=\"form.getTypeNameById(response.typeId)\"\n [wallet]=\"response.wallet\"\n [maskedWallet]=\"maskedWallet\"\n [amount]=\"response.amount\"\n [total]=\"response.total\"\n [confirmationText]=\"form.config?.confirmation\"\n >\n @if (error && !form.payment.pending) {\n <div class=\"trm-error\"\n app-constructor-preparation-error\n @insertRemove\n >\n {{ error | trans }}\n </div>\n }\n </app-constructor-preparation>\n }\n <div class=\"constructor__actions\"\n @insertRemove>\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\n type=\"submit\"\n [tabindex]=\"form.fields.length + tabIndex\">\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\n @if (loading) {\n <span class=\"trm-spinner trm-spinner-white\"></span>\n }\n </button>\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\n type=\"button\"\n [tabindex]=\"form.fields.length + tabIndex\"\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\n </div>\n } @else {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n }\n</form>\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:1px;right:1px;flex-shrink:0;min-height:44px}@media (min-width: 768px){.constructor__currency{min-height:48px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
|
|
5871
5871
|
}], propDecorators: { step: [{
|
|
5872
5872
|
type: Input
|
|
5873
5873
|
}], error: [{
|
|
@@ -6120,7 +6120,7 @@ class TerminalLayoutComponent {
|
|
|
6120
6120
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.14", type: TerminalLayoutComponent, isStandalone: true, selector: "app-terminal-layout", providers: [
|
|
6121
6121
|
SessionDataSource,
|
|
6122
6122
|
CurrencyPipe
|
|
6123
|
-
], viewQueries: [{ propertyName: "scrollComponent", first: true, predicate: ["scrollComponent"], descendants: true }], ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\
|
|
6123
|
+
], viewQueries: [{ propertyName: "scrollComponent", first: true, predicate: ["scrollComponent"], descendants: true }], ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\n <div class=\"terminal-layout\">\n <section class=\"terminal\">\n <div class=\"terminal__content\">\n <header class=\"terminal__header\">\n <i class=\"terminal__header-logo\"\n [class]=\"logoClass\"></i>\n <div class=\"terminal__header-lang\">\n @if (hasChoice) {\n <app-terminal-lang-switcher (langChange)=\"changeLang()\"\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\n }\n </div>\n </header>\n <div class=\"terminal__form\">\n @if (sessionDS.loading$ | async) {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n } @else {\n @if (projectName) {\n <div class=\"terminal__info\">\n <h5 class=\"terminal__info__name\"> {{ projectName }} </h5>\n @if (description) {\n <p class=\"terminal__info__desc\"> {{ description }} </p>\n }\n </div>\n }\n @if (step !== TERMINAL_STEP.Status && !hasStatusError) {\n <app-constructor-form\n [feeLoading]=\"feeLoading\"\n [feeOptions]=\"feeOptions\"\n [loading]=\"sessionLoading\"\n [step]=\"step\"\n [types]=\"types\"\n [currency]=\"currency\"\n [response]=\"data\"\n [error]=\"statusText\"\n (prepare)=\"prepare($event)\"\n (onPaymentChanged)=\"checkFatalError(); calculateFee($event)\"\n (back)=\"back()\"\n [canReturnToProject]=\"sessionDS.canReturnToProject\"\n (confirm)=\"confirm()\"\n [tabIndex]=\"2\"></app-constructor-form>\n } @else {\n <app-constructor-status class=\"terminal__status\"\n [failed]=\"hasStatusError\"\n [message]=\"statusText ? (statusText | trans) : ''\"\n [backUrl]=\"returnBackUrl\"\n ></app-constructor-status>\n }\n }\n\n </div>\n </div>\n </section>\n <footer class=\"terminal-footer\">\n <i class=\"terminal-footer__logo\"></i>\n <p class=\"terminal-footer__txt\">\n {{ footerText }}\n </p>\n </footer>\n </div>\n</ng-scrollbar>\n", styles: [":host{display:flex;flex-direction:column;height:100vh;box-sizing:border-box}.terminal{box-sizing:border-box;width:100%;max-width:528px;min-width:320px;padding:0 10px}.terminal-layout{min-height:100vh;padding:42px 0 84px;display:flex;flex-direction:column;gap:42px;justify-content:flex-start;align-items:center}.terminal-footer{flex:auto 1 0;display:flex;flex-direction:column;gap:24px;justify-content:flex-end;align-items:center}.terminal-footer__txt{font-weight:400;font-size:14px;line-height:18px;color:var(--color-base-350);margin:0}.terminal__content{box-sizing:border-box;margin:auto;padding:20px;width:100%;background:#fff;border-radius:16px;display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}@media (min-width: 768px){.terminal__content{padding:32px}}.terminal__header{display:flex;flex-direction:row;gap:0;justify-content:flex-start;align-items:center}.terminal__header-lang{margin-left:auto}.terminal__form{display:flex;flex-direction:column;gap:24px;justify-content:flex-start;align-items:stretch;width:100%}.terminal__info{background:#f5f5f5;border-radius:16px;padding:20px 24px;display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.terminal__info__name{margin:0;font-weight:500;font-size:16px;line-height:20px;color:#000}.terminal__info__desc{margin:0;font-weight:400;font-size:15px;line-height:22px;color:var(--color-base-350)}.terminal__status{margin-top:8px}.terminal .trm-skeleton-group{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.terminal .trm-skeleton-group__form{gap:20px}.terminal .trm-skeleton-group__form .loader,.terminal .trm-skeleton-group__form .skeleton-loader{height:80px}.terminal .trm-skeleton-group__header .loader,.terminal .trm-skeleton-group__header .skeleton-loader{height:120px}.terminal .trm-skeleton-group__actions{gap:10px}.terminal .trm-skeleton-group__actions .loader,.terminal .trm-skeleton-group__actions .skeleton-loader{height:48px}\n"], dependencies: [{ kind: "component", type: NgScrollbar, selector: "ng-scrollbar:not([externalViewport])", exportAs: ["ngScrollbar"] }, { kind: "component", type: TerminalLangSwitcherComponent, selector: "app-terminal-lang-switcher", inputs: ["loading", "tabIndex"], outputs: ["langChange"] }, { kind: "component", type: ConstructorFormComponent, selector: "app-constructor-form", inputs: ["step", "error", "response", "feeLoading", "feeOptions", "currency", "userCurrency", "loading", "types", "canReturnToProject", "tabIndex"], outputs: ["amountChanged", "back", "prepare", "confirm", "onPaymentChanged"] }, { kind: "component", type: ConstructorStatusComponent, selector: "app-constructor-status", inputs: ["failed", "inProgress", "animation", "message", "failTitle", "progressTitle", "successTitle", "tabIndex", "backUrl", "backUrlTitle", "hasSupportHint"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }] }); }
|
|
6124
6124
|
}
|
|
6125
6125
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: TerminalLayoutComponent, decorators: [{
|
|
6126
6126
|
type: Component,
|
|
@@ -6133,7 +6133,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
6133
6133
|
ConstructorFormComponent, ConstructorStatusComponent,
|
|
6134
6134
|
AsyncPipe,
|
|
6135
6135
|
TranslateByKeyPipe, GmSkeletonComponent
|
|
6136
|
-
], template: "<ng-scrollbar appearance=\"compact\">\
|
|
6136
|
+
], template: "<ng-scrollbar appearance=\"compact\">\n <div class=\"terminal-layout\">\n <section class=\"terminal\">\n <div class=\"terminal__content\">\n <header class=\"terminal__header\">\n <i class=\"terminal__header-logo\"\n [class]=\"logoClass\"></i>\n <div class=\"terminal__header-lang\">\n @if (hasChoice) {\n <app-terminal-lang-switcher (langChange)=\"changeLang()\"\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\n }\n </div>\n </header>\n <div class=\"terminal__form\">\n @if (sessionDS.loading$ | async) {\n <div class=\"trm-skeleton-group\">\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\n </div>\n } @else {\n @if (projectName) {\n <div class=\"terminal__info\">\n <h5 class=\"terminal__info__name\"> {{ projectName }} </h5>\n @if (description) {\n <p class=\"terminal__info__desc\"> {{ description }} </p>\n }\n </div>\n }\n @if (step !== TERMINAL_STEP.Status && !hasStatusError) {\n <app-constructor-form\n [feeLoading]=\"feeLoading\"\n [feeOptions]=\"feeOptions\"\n [loading]=\"sessionLoading\"\n [step]=\"step\"\n [types]=\"types\"\n [currency]=\"currency\"\n [response]=\"data\"\n [error]=\"statusText\"\n (prepare)=\"prepare($event)\"\n (onPaymentChanged)=\"checkFatalError(); calculateFee($event)\"\n (back)=\"back()\"\n [canReturnToProject]=\"sessionDS.canReturnToProject\"\n (confirm)=\"confirm()\"\n [tabIndex]=\"2\"></app-constructor-form>\n } @else {\n <app-constructor-status class=\"terminal__status\"\n [failed]=\"hasStatusError\"\n [message]=\"statusText ? (statusText | trans) : ''\"\n [backUrl]=\"returnBackUrl\"\n ></app-constructor-status>\n }\n }\n\n </div>\n </div>\n </section>\n <footer class=\"terminal-footer\">\n <i class=\"terminal-footer__logo\"></i>\n <p class=\"terminal-footer__txt\">\n {{ footerText }}\n </p>\n </footer>\n </div>\n</ng-scrollbar>\n", styles: [":host{display:flex;flex-direction:column;height:100vh;box-sizing:border-box}.terminal{box-sizing:border-box;width:100%;max-width:528px;min-width:320px;padding:0 10px}.terminal-layout{min-height:100vh;padding:42px 0 84px;display:flex;flex-direction:column;gap:42px;justify-content:flex-start;align-items:center}.terminal-footer{flex:auto 1 0;display:flex;flex-direction:column;gap:24px;justify-content:flex-end;align-items:center}.terminal-footer__txt{font-weight:400;font-size:14px;line-height:18px;color:var(--color-base-350);margin:0}.terminal__content{box-sizing:border-box;margin:auto;padding:20px;width:100%;background:#fff;border-radius:16px;display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}@media (min-width: 768px){.terminal__content{padding:32px}}.terminal__header{display:flex;flex-direction:row;gap:0;justify-content:flex-start;align-items:center}.terminal__header-lang{margin-left:auto}.terminal__form{display:flex;flex-direction:column;gap:24px;justify-content:flex-start;align-items:stretch;width:100%}.terminal__info{background:#f5f5f5;border-radius:16px;padding:20px 24px;display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.terminal__info__name{margin:0;font-weight:500;font-size:16px;line-height:20px;color:#000}.terminal__info__desc{margin:0;font-weight:400;font-size:15px;line-height:22px;color:var(--color-base-350)}.terminal__status{margin-top:8px}.terminal .trm-skeleton-group{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.terminal .trm-skeleton-group__form{gap:20px}.terminal .trm-skeleton-group__form .loader,.terminal .trm-skeleton-group__form .skeleton-loader{height:80px}.terminal .trm-skeleton-group__header .loader,.terminal .trm-skeleton-group__header .skeleton-loader{height:120px}.terminal .trm-skeleton-group__actions{gap:10px}.terminal .trm-skeleton-group__actions .loader,.terminal .trm-skeleton-group__actions .skeleton-loader{height:48px}\n"] }]
|
|
6137
6137
|
}], ctorParameters: () => [], propDecorators: { scrollComponent: [{
|
|
6138
6138
|
type: ViewChild,
|
|
6139
6139
|
args: ['scrollComponent']
|
|
@@ -6149,7 +6149,7 @@ class ErrorComponent {
|
|
|
6149
6149
|
this.I18N_KEY = I18N_KEY;
|
|
6150
6150
|
}
|
|
6151
6151
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
6152
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ErrorComponent, isStandalone: true, selector: "app-error", ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"false\">\
|
|
6152
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "19.2.14", type: ErrorComponent, isStandalone: true, selector: "app-error", ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"false\">\n <app-constructor-status terminal-layout-status\n [failed]=\"true\"\n [failTitle]=\"(I18N_KEY.ERROR_OCCUR | trans)\"\n [hasSupportHint]=\"false\"\n >\n </app-constructor-status>\n</app-terminal-layout-tpl>\n", styles: [""], dependencies: [{ kind: "component", type: TerminalLayoutTplComponent, selector: "app-terminal-layout-tpl", inputs: ["projectName", "description", "loading"] }, { kind: "component", type: ConstructorStatusComponent, selector: "app-constructor-status", inputs: ["failed", "inProgress", "animation", "message", "failTitle", "progressTitle", "successTitle", "tabIndex", "backUrl", "backUrlTitle", "hasSupportHint"] }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }] }); }
|
|
6153
6153
|
}
|
|
6154
6154
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: ErrorComponent, decorators: [{
|
|
6155
6155
|
type: Component,
|
|
@@ -6157,7 +6157,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
6157
6157
|
TerminalLayoutTplComponent,
|
|
6158
6158
|
ConstructorStatusComponent,
|
|
6159
6159
|
TranslateByKeyPipe,
|
|
6160
|
-
], template: "<app-terminal-layout-tpl [loading]=\"false\">\
|
|
6160
|
+
], template: "<app-terminal-layout-tpl [loading]=\"false\">\n <app-constructor-status terminal-layout-status\n [failed]=\"true\"\n [failTitle]=\"(I18N_KEY.ERROR_OCCUR | trans)\"\n [hasSupportHint]=\"false\"\n >\n </app-constructor-status>\n</app-terminal-layout-tpl>\n" }]
|
|
6161
6161
|
}] });
|
|
6162
6162
|
|
|
6163
6163
|
var error_component = /*#__PURE__*/Object.freeze({
|
|
@@ -6511,7 +6511,7 @@ class CheckinPageComponent {
|
|
|
6511
6511
|
useFactory: (activatedRoute) => activatedRoute.snapshot.paramMap.get('mode')
|
|
6512
6512
|
},
|
|
6513
6513
|
CheckinDatasource
|
|
6514
|
-
], ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\
|
|
6514
|
+
], ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\n @if (!(loading | async)) {\n <app-constructor-status terminal-layout-status\n [inProgress]=\"inProgress\"\n [failed]=\"hasStatusError\"\n [animation]=\"animation\"\n [progressTitle]=\"(I18N_KEY.PROGRESS_TITLE | trans)\"\n [failTitle]=\"(I18N_KEY.FAIL_TITLE | trans)\"\n [successTitle]=\"(I18N_KEY.SUCCESS_TITLE | trans)\"\n [hasSupportHint]=\"false\"\n [message]=\"(message | trans) + operationIdHint\"\n [backUrl]=\"returnBackUrl\"\n [backUrlTitle]=\"I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans\"\n >\n @if (redirectTimerStarted) {\n <div constructor-status-button-hint>\n {{ I18N_KEY.REDIRECT_TEXT | trans }} <b>{{redirectTime}}</b>\n </div>\n }\n </app-constructor-status>\n }\n</app-terminal-layout-tpl>\n", styles: [""], dependencies: [{ kind: "component", type: TerminalLayoutTplComponent, selector: "app-terminal-layout-tpl", inputs: ["projectName", "description", "loading"] }, { kind: "component", type: ConstructorStatusComponent, selector: "app-constructor-status", inputs: ["failed", "inProgress", "animation", "message", "failTitle", "progressTitle", "successTitle", "tabIndex", "backUrl", "backUrlTitle", "hasSupportHint"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }] }); }
|
|
6515
6515
|
}
|
|
6516
6516
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImport: i0, type: CheckinPageComponent, decorators: [{
|
|
6517
6517
|
type: Component,
|
|
@@ -6522,7 +6522,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.14", ngImpo
|
|
|
6522
6522
|
useFactory: (activatedRoute) => activatedRoute.snapshot.paramMap.get('mode')
|
|
6523
6523
|
},
|
|
6524
6524
|
CheckinDatasource
|
|
6525
|
-
], imports: [TerminalLayoutTplComponent, ConstructorStatusComponent, AsyncPipe, TranslateByKeyPipe], template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\
|
|
6525
|
+
], imports: [TerminalLayoutTplComponent, ConstructorStatusComponent, AsyncPipe, TranslateByKeyPipe], template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\n @if (!(loading | async)) {\n <app-constructor-status terminal-layout-status\n [inProgress]=\"inProgress\"\n [failed]=\"hasStatusError\"\n [animation]=\"animation\"\n [progressTitle]=\"(I18N_KEY.PROGRESS_TITLE | trans)\"\n [failTitle]=\"(I18N_KEY.FAIL_TITLE | trans)\"\n [successTitle]=\"(I18N_KEY.SUCCESS_TITLE | trans)\"\n [hasSupportHint]=\"false\"\n [message]=\"(message | trans) + operationIdHint\"\n [backUrl]=\"returnBackUrl\"\n [backUrlTitle]=\"I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans\"\n >\n @if (redirectTimerStarted) {\n <div constructor-status-button-hint>\n {{ I18N_KEY.REDIRECT_TEXT | trans }} <b>{{redirectTime}}</b>\n </div>\n }\n </app-constructor-status>\n }\n</app-terminal-layout-tpl>\n" }]
|
|
6526
6526
|
}], ctorParameters: () => [] });
|
|
6527
6527
|
|
|
6528
6528
|
var checkinPage_component = /*#__PURE__*/Object.freeze({
|