trm-tmpl 3.3.0 → 3.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (377) hide show
  1. package/README.md +24 -24
  2. package/assets/svg/arrow_down.svg +3 -3
  3. package/assets/svg/currencies/brl.svg +5 -5
  4. package/assets/svg/currencies/btc.svg +4 -4
  5. package/assets/svg/currencies/cny.svg +4 -4
  6. package/assets/svg/currencies/eth.svg +9 -9
  7. package/assets/svg/currencies/eur.svg +4 -4
  8. package/assets/svg/currencies/gbp.svg +4 -4
  9. package/assets/svg/currencies/kzt.svg +4 -4
  10. package/assets/svg/currencies/mxn.svg +5 -5
  11. package/assets/svg/currencies/rub.svg +4 -4
  12. package/assets/svg/currencies/trx.svg +11 -11
  13. package/assets/svg/currencies/uah.svg +4 -4
  14. package/assets/svg/currencies/usd.svg +4 -4
  15. package/assets/svg/currencies/usdt.svg +4 -4
  16. package/assets/svg/datepicker.svg +9 -9
  17. package/assets/svg/es.svg +573 -573
  18. package/assets/svg/flags/ab.svg +23 -23
  19. package/assets/svg/flags/os.svg +12 -12
  20. package/assets/svg/flags/other.svg +19 -19
  21. package/assets/svg/pay/advcash.svg +6 -6
  22. package/assets/svg/pay/alfabank.svg +5 -5
  23. package/assets/svg/pay/alipay.svg +5 -5
  24. package/assets/svg/pay/alipay_plus.svg +6 -6
  25. package/assets/svg/pay/applepay.svg +4 -4
  26. package/assets/svg/pay/argentina_bank.svg +74 -74
  27. package/assets/svg/pay/atf24.svg +14 -14
  28. package/assets/svg/pay/baloto.svg +8 -8
  29. package/assets/svg/pay/bancontact.svg +16 -16
  30. package/assets/svg/pay/beeline.svg +19 -19
  31. package/assets/svg/pay/bitcoin.svg +4 -4
  32. package/assets/svg/pay/blik.svg +12 -12
  33. package/assets/svg/pay/boleto.svg +39 -39
  34. package/assets/svg/pay/brazil_bank.svg +27 -27
  35. package/assets/svg/pay/card.svg +4 -4
  36. package/assets/svg/pay/carga_virtual.svg +30 -30
  37. package/assets/svg/pay/cash.svg +6 -6
  38. package/assets/svg/pay/cashtocode.svg +6 -6
  39. package/assets/svg/pay/codi.svg +10 -10
  40. package/assets/svg/pay/comepay.svg +41 -41
  41. package/assets/svg/pay/cup.svg +6 -6
  42. package/assets/svg/pay/cup_bank.svg +10 -10
  43. package/assets/svg/pay/cup_p2p.svg +9 -9
  44. package/assets/svg/pay/deposit_express.svg +8 -8
  45. package/assets/svg/pay/direct_banking_europe.svg +8 -8
  46. package/assets/svg/pay/dotpay.svg +6 -6
  47. package/assets/svg/pay/ecopayz.svg +7 -7
  48. package/assets/svg/pay/eps.svg +6 -6
  49. package/assets/svg/pay/ethereum.svg +9 -9
  50. package/assets/svg/pay/g2a.svg +7 -7
  51. package/assets/svg/pay/giropay.svg +5 -5
  52. package/assets/svg/pay/gmmoney.svg +4 -4
  53. package/assets/svg/pay/googlepay.svg +7 -7
  54. package/assets/svg/pay/ideal.svg +7 -7
  55. package/assets/svg/pay/indonesia_bank.svg +4 -4
  56. package/assets/svg/pay/jeton.svg +4 -4
  57. package/assets/svg/pay/kassa24.svg +10 -10
  58. package/assets/svg/pay/link.svg +14 -14
  59. package/assets/svg/pay/local_card_mexico.svg +16 -16
  60. package/assets/svg/pay/loterica.svg +7 -7
  61. package/assets/svg/pay/malaysia_bank.svg +16 -16
  62. package/assets/svg/pay/mbway.svg +6 -6
  63. package/assets/svg/pay/megafon.svg +5 -5
  64. package/assets/svg/pay/mercado_pago.svg +9 -9
  65. package/assets/svg/pay/mexico_bank.svg +14 -14
  66. package/assets/svg/pay/mirpay.svg +4 -4
  67. package/assets/svg/pay/momopay.svg +4 -4
  68. package/assets/svg/pay/moneta.svg +5 -5
  69. package/assets/svg/pay/mts.svg +4 -4
  70. package/assets/svg/pay/multibanco.svg +6 -6
  71. package/assets/svg/pay/neosurf.svg +4 -4
  72. package/assets/svg/pay/neteller.svg +4 -4
  73. package/assets/svg/pay/nupay.svg +4 -4
  74. package/assets/svg/pay/onecard.svg +6 -6
  75. package/assets/svg/pay/oxxo.svg +8 -8
  76. package/assets/svg/pay/pagoefectivo.svg +4 -4
  77. package/assets/svg/pay/pagoexpress.svg +5 -5
  78. package/assets/svg/pay/pagofacil.svg +5 -5
  79. package/assets/svg/pay/paypal.svg +7 -7
  80. package/assets/svg/pay/paysafecard.svg +5 -5
  81. package/assets/svg/pay/philippines_bank.svg +12 -12
  82. package/assets/svg/pay/picpay.svg +4 -4
  83. package/assets/svg/pay/pix.svg +6 -6
  84. package/assets/svg/pay/polish_bank.svg +4 -4
  85. package/assets/svg/pay/promptpay.svg +4 -4
  86. package/assets/svg/pay/promsviaz.svg +5 -5
  87. package/assets/svg/pay/przelewy24.svg +6 -6
  88. package/assets/svg/pay/qiwi.svg +6 -6
  89. package/assets/svg/pay/rapid.svg +5 -5
  90. package/assets/svg/pay/rapipago.svg +5 -5
  91. package/assets/svg/pay/redcompra.svg +4 -4
  92. package/assets/svg/pay/redpagos.svg +5 -5
  93. package/assets/svg/pay/sberbank.svg +23 -23
  94. package/assets/svg/pay/sbp.svg +11 -11
  95. package/assets/svg/pay/sepa.svg +7 -7
  96. package/assets/svg/pay/servipag.svg +7 -7
  97. package/assets/svg/pay/skinify.svg +5 -5
  98. package/assets/svg/pay/skinpay.svg +4 -4
  99. package/assets/svg/pay/skinsback.svg +4 -4
  100. package/assets/svg/pay/skrill.svg +4 -4
  101. package/assets/svg/pay/sofort.svg +4 -4
  102. package/assets/svg/pay/spei.svg +8 -8
  103. package/assets/svg/pay/steam.svg +15 -15
  104. package/assets/svg/pay/store_mexico.svg +8 -8
  105. package/assets/svg/pay/tele2.svg +4 -4
  106. package/assets/svg/pay/tether.svg +4 -4
  107. package/assets/svg/pay/thailand_bank.svg +10 -10
  108. package/assets/svg/pay/tinkoff.svg +38 -38
  109. package/assets/svg/pay/tron.svg +11 -11
  110. package/assets/svg/pay/trustly.svg +4 -4
  111. package/assets/svg/pay/vietnam_bank.svg +4 -4
  112. package/assets/svg/pay/wallester.svg +35 -35
  113. package/assets/svg/pay/webmoney.svg +4 -4
  114. package/assets/svg/pay/webpay.svg +5 -5
  115. package/assets/svg/pay/wechat.svg +5 -5
  116. package/assets/svg/pay/yandex.svg +5 -5
  117. package/assets/svg/pay/zen_wallet.svg +5 -5
  118. package/assets/svg/pci-dss.svg +19 -19
  119. package/assets/svg/pt.svg +144 -144
  120. package/assets/svg/ru.svg +16 -16
  121. package/assets/svg/status-error.svg +5 -5
  122. package/assets/svg/status-success.svg +4 -4
  123. package/assets/svg/status-wait-rotate.svg +18 -18
  124. package/assets/svg/status-wait.svg +11 -11
  125. package/assets/svg/tr.svg +13 -13
  126. package/assets/svg/us.svg +13 -13
  127. package/assets/svg/wait.svg +11 -11
  128. package/esm2022/lib/app/checkin/checkin.module.mjs +1 -1
  129. package/esm2022/lib/app/checkin/components/checkin-page/checkin-page.component.mjs +3 -3
  130. package/esm2022/lib/app/checkin/components/index.mjs +1 -1
  131. package/esm2022/lib/app/checkin/index.mjs +1 -1
  132. package/esm2022/lib/app/checkin/services/checkin.datasource.mjs +1 -1
  133. package/esm2022/lib/app/checkin/services/index.mjs +1 -1
  134. package/esm2022/lib/app/helpers/hide-init-loader.mjs +1 -1
  135. package/esm2022/lib/app/helpers/i18n-countries.mjs +1 -1
  136. package/esm2022/lib/app/helpers/index.mjs +1 -1
  137. package/esm2022/lib/app/helpers/insertRemoveTrigger.mjs +1 -1
  138. package/esm2022/lib/app/helpers/is-object-the-same.mjs +1 -1
  139. package/esm2022/lib/app/helpers/key-down-handler.mjs +1 -1
  140. package/esm2022/lib/app/helpers/mask-resolver.mjs +1 -1
  141. package/esm2022/lib/app/helpers/phone-codes.mjs +1 -1
  142. package/esm2022/lib/app/helpers/warning-console-message.mjs +1 -1
  143. package/esm2022/lib/app/i18n/i18n-key.enum.mjs +1 -1
  144. package/esm2022/lib/app/i18n/index.mjs +1 -1
  145. package/esm2022/lib/app/i18n/keys.mjs +1 -1
  146. package/esm2022/lib/app/intex.mjs +1 -1
  147. package/esm2022/lib/app/models/cde-terminal-sdk.mjs +1 -1
  148. package/esm2022/lib/app/models/constants.mjs +1 -1
  149. package/esm2022/lib/app/models/http-bad-request-response.mjs +1 -1
  150. package/esm2022/lib/app/models/index.mjs +1 -1
  151. package/esm2022/lib/app/models/mode.mjs +1 -1
  152. package/esm2022/lib/app/models/version-service-base-class.mjs +1 -1
  153. package/esm2022/lib/app/models/version-service-interface.mjs +1 -1
  154. package/esm2022/lib/app/models/version.interface.mjs +1 -1
  155. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-date/constructor-field-date.component.mjs +3 -3
  156. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/card-sdk.service.mjs +1 -1
  157. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/constructor-field-iframe.component.mjs +3 -3
  158. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-iframe/iframe-validator-directive.directive.mjs +1 -1
  159. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-select/constructor-field-select.component.mjs +3 -3
  160. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-field-text/constructor-field-text.component.mjs +3 -3
  161. package/esm2022/lib/app/pages/components/constructor-form/components/constructor-preparation/constructor-preparation.component.mjs +3 -3
  162. package/esm2022/lib/app/pages/components/constructor-form/components/index.mjs +1 -1
  163. package/esm2022/lib/app/pages/components/constructor-form/components/method-amount-hint/method-amount-hint.component.mjs +3 -3
  164. package/esm2022/lib/app/pages/components/constructor-form/components/ps-select/ps-select.component.mjs +3 -3
  165. package/esm2022/lib/app/pages/components/constructor-form/constructor-form.component.mjs +3 -3
  166. package/esm2022/lib/app/pages/components/constructor-form/index.mjs +1 -1
  167. package/esm2022/lib/app/pages/components/constructor-form/models/collection-type.enum.mjs +1 -1
  168. package/esm2022/lib/app/pages/components/constructor-form/models/config/advcash.mjs +1 -1
  169. package/esm2022/lib/app/pages/components/constructor-form/models/config/alfabank.mjs +1 -1
  170. package/esm2022/lib/app/pages/components/constructor-form/models/config/alipay.mjs +1 -1
  171. package/esm2022/lib/app/pages/components/constructor-form/models/config/alipay_plus.mjs +1 -1
  172. package/esm2022/lib/app/pages/components/constructor-form/models/config/all.mjs +1 -1
  173. package/esm2022/lib/app/pages/components/constructor-form/models/config/applepay.mjs +1 -1
  174. package/esm2022/lib/app/pages/components/constructor-form/models/config/argentina_bank.mjs +1 -1
  175. package/esm2022/lib/app/pages/components/constructor-form/models/config/atf24.mjs +1 -1
  176. package/esm2022/lib/app/pages/components/constructor-form/models/config/baloto.mjs +1 -1
  177. package/esm2022/lib/app/pages/components/constructor-form/models/config/beeline.mjs +1 -1
  178. package/esm2022/lib/app/pages/components/constructor-form/models/config/bitcoin.mjs +1 -1
  179. package/esm2022/lib/app/pages/components/constructor-form/models/config/blik.mjs +1 -1
  180. package/esm2022/lib/app/pages/components/constructor-form/models/config/boleto.mjs +1 -1
  181. package/esm2022/lib/app/pages/components/constructor-form/models/config/brazil_bank.mjs +1 -1
  182. package/esm2022/lib/app/pages/components/constructor-form/models/config/card.mjs +1 -1
  183. package/esm2022/lib/app/pages/components/constructor-form/models/config/carga_virtual.mjs +1 -1
  184. package/esm2022/lib/app/pages/components/constructor-form/models/config/cash.mjs +1 -1
  185. package/esm2022/lib/app/pages/components/constructor-form/models/config/cashtocode.mjs +1 -1
  186. package/esm2022/lib/app/pages/components/constructor-form/models/config/codi.mjs +1 -1
  187. package/esm2022/lib/app/pages/components/constructor-form/models/config/comepay.mjs +1 -1
  188. package/esm2022/lib/app/pages/components/constructor-form/models/config/cup.mjs +1 -1
  189. package/esm2022/lib/app/pages/components/constructor-form/models/config/cup_bank.mjs +1 -1
  190. package/esm2022/lib/app/pages/components/constructor-form/models/config/cup_p2p.mjs +1 -1
  191. package/esm2022/lib/app/pages/components/constructor-form/models/config/deposit_express.mjs +1 -1
  192. package/esm2022/lib/app/pages/components/constructor-form/models/config/direct_banking_europe.mjs +1 -1
  193. package/esm2022/lib/app/pages/components/constructor-form/models/config/dotpay.mjs +1 -1
  194. package/esm2022/lib/app/pages/components/constructor-form/models/config/ecopayz.mjs +1 -1
  195. package/esm2022/lib/app/pages/components/constructor-form/models/config/eps.mjs +1 -1
  196. package/esm2022/lib/app/pages/components/constructor-form/models/config/ethereum.mjs +1 -1
  197. package/esm2022/lib/app/pages/components/constructor-form/models/config/giropay.mjs +1 -1
  198. package/esm2022/lib/app/pages/components/constructor-form/models/config/gmmoney.mjs +1 -1
  199. package/esm2022/lib/app/pages/components/constructor-form/models/config/googlepay.mjs +1 -1
  200. package/esm2022/lib/app/pages/components/constructor-form/models/config/ideal.mjs +1 -1
  201. package/esm2022/lib/app/pages/components/constructor-form/models/config/indonesia_bank.mjs +1 -1
  202. package/esm2022/lib/app/pages/components/constructor-form/models/config/indonesia_bank_transfer.mjs +1 -1
  203. package/esm2022/lib/app/pages/components/constructor-form/models/config/internal_gamemoney.mjs +1 -1
  204. package/esm2022/lib/app/pages/components/constructor-form/models/config/jeton.mjs +1 -1
  205. package/esm2022/lib/app/pages/components/constructor-form/models/config/jeton_voucher.mjs +1 -1
  206. package/esm2022/lib/app/pages/components/constructor-form/models/config/kassa24.mjs +1 -1
  207. package/esm2022/lib/app/pages/components/constructor-form/models/config/link.mjs +1 -1
  208. package/esm2022/lib/app/pages/components/constructor-form/models/config/local_card_brazil.mjs +1 -1
  209. package/esm2022/lib/app/pages/components/constructor-form/models/config/local_card_mexico.mjs +1 -1
  210. package/esm2022/lib/app/pages/components/constructor-form/models/config/loterica.mjs +1 -1
  211. package/esm2022/lib/app/pages/components/constructor-form/models/config/malaysia_bank.mjs +1 -1
  212. package/esm2022/lib/app/pages/components/constructor-form/models/config/mbway.mjs +1 -1
  213. package/esm2022/lib/app/pages/components/constructor-form/models/config/megafon.mjs +1 -1
  214. package/esm2022/lib/app/pages/components/constructor-form/models/config/mercado_pago.mjs +1 -1
  215. package/esm2022/lib/app/pages/components/constructor-form/models/config/mexico_bank.mjs +1 -1
  216. package/esm2022/lib/app/pages/components/constructor-form/models/config/mirpay.mjs +1 -1
  217. package/esm2022/lib/app/pages/components/constructor-form/models/config/momopay.mjs +1 -1
  218. package/esm2022/lib/app/pages/components/constructor-form/models/config/moneta.mjs +1 -1
  219. package/esm2022/lib/app/pages/components/constructor-form/models/config/mts.mjs +1 -1
  220. package/esm2022/lib/app/pages/components/constructor-form/models/config/multibanco.mjs +1 -1
  221. package/esm2022/lib/app/pages/components/constructor-form/models/config/neosurf.mjs +1 -1
  222. package/esm2022/lib/app/pages/components/constructor-form/models/config/neteller.mjs +1 -1
  223. package/esm2022/lib/app/pages/components/constructor-form/models/config/nupay.mjs +1 -1
  224. package/esm2022/lib/app/pages/components/constructor-form/models/config/onecard.mjs +1 -1
  225. package/esm2022/lib/app/pages/components/constructor-form/models/config/oxxo.mjs +1 -1
  226. package/esm2022/lib/app/pages/components/constructor-form/models/config/pagoefectivo.mjs +1 -1
  227. package/esm2022/lib/app/pages/components/constructor-form/models/config/pagoexpress.mjs +1 -1
  228. package/esm2022/lib/app/pages/components/constructor-form/models/config/pagofacil.mjs +1 -1
  229. package/esm2022/lib/app/pages/components/constructor-form/models/config/paypal.mjs +1 -1
  230. package/esm2022/lib/app/pages/components/constructor-form/models/config/paysafecard.mjs +1 -1
  231. package/esm2022/lib/app/pages/components/constructor-form/models/config/philippines_bank.mjs +1 -1
  232. package/esm2022/lib/app/pages/components/constructor-form/models/config/picpay.mjs +1 -1
  233. package/esm2022/lib/app/pages/components/constructor-form/models/config/pix.mjs +1 -1
  234. package/esm2022/lib/app/pages/components/constructor-form/models/config/promptpay.mjs +1 -1
  235. package/esm2022/lib/app/pages/components/constructor-form/models/config/promsviaz.mjs +1 -1
  236. package/esm2022/lib/app/pages/components/constructor-form/models/config/przelewy24.mjs +1 -1
  237. package/esm2022/lib/app/pages/components/constructor-form/models/config/qiwi.mjs +1 -1
  238. package/esm2022/lib/app/pages/components/constructor-form/models/config/rapid.mjs +1 -1
  239. package/esm2022/lib/app/pages/components/constructor-form/models/config/rapipago.mjs +1 -1
  240. package/esm2022/lib/app/pages/components/constructor-form/models/config/redpagos.mjs +1 -1
  241. package/esm2022/lib/app/pages/components/constructor-form/models/config/sberbank.mjs +1 -1
  242. package/esm2022/lib/app/pages/components/constructor-form/models/config/sbp.mjs +1 -1
  243. package/esm2022/lib/app/pages/components/constructor-form/models/config/sepa.mjs +1 -1
  244. package/esm2022/lib/app/pages/components/constructor-form/models/config/servipag.mjs +1 -1
  245. package/esm2022/lib/app/pages/components/constructor-form/models/config/skinify.mjs +1 -1
  246. package/esm2022/lib/app/pages/components/constructor-form/models/config/skinpay.mjs +1 -1
  247. package/esm2022/lib/app/pages/components/constructor-form/models/config/skinsback.mjs +1 -1
  248. package/esm2022/lib/app/pages/components/constructor-form/models/config/skrill.mjs +1 -1
  249. package/esm2022/lib/app/pages/components/constructor-form/models/config/sofort.mjs +1 -1
  250. package/esm2022/lib/app/pages/components/constructor-form/models/config/spei.mjs +1 -1
  251. package/esm2022/lib/app/pages/components/constructor-form/models/config/store_mexico.mjs +1 -1
  252. package/esm2022/lib/app/pages/components/constructor-form/models/config/tele2.mjs +1 -1
  253. package/esm2022/lib/app/pages/components/constructor-form/models/config/tether.mjs +1 -1
  254. package/esm2022/lib/app/pages/components/constructor-form/models/config/tether_trc20.mjs +1 -1
  255. package/esm2022/lib/app/pages/components/constructor-form/models/config/thailand_bank.mjs +1 -1
  256. package/esm2022/lib/app/pages/components/constructor-form/models/config/thailand_bank_transfer.mjs +1 -1
  257. package/esm2022/lib/app/pages/components/constructor-form/models/config/tinkoff.mjs +1 -1
  258. package/esm2022/lib/app/pages/components/constructor-form/models/config/tron.mjs +1 -1
  259. package/esm2022/lib/app/pages/components/constructor-form/models/config/trustly.mjs +1 -1
  260. package/esm2022/lib/app/pages/components/constructor-form/models/config/vietnam_bank.mjs +1 -1
  261. package/esm2022/lib/app/pages/components/constructor-form/models/config/vietnam_bank_qr.mjs +1 -1
  262. package/esm2022/lib/app/pages/components/constructor-form/models/config/vietnam_bank_transfer.mjs +1 -1
  263. package/esm2022/lib/app/pages/components/constructor-form/models/config/wallester.mjs +1 -1
  264. package/esm2022/lib/app/pages/components/constructor-form/models/config/webpay.mjs +1 -1
  265. package/esm2022/lib/app/pages/components/constructor-form/models/config/wechat.mjs +1 -1
  266. package/esm2022/lib/app/pages/components/constructor-form/models/config/wme.mjs +1 -1
  267. package/esm2022/lib/app/pages/components/constructor-form/models/config/wmr.mjs +1 -1
  268. package/esm2022/lib/app/pages/components/constructor-form/models/config/wmu.mjs +1 -1
  269. package/esm2022/lib/app/pages/components/constructor-form/models/config/wmz.mjs +1 -1
  270. package/esm2022/lib/app/pages/components/constructor-form/models/config/yandex.mjs +1 -1
  271. package/esm2022/lib/app/pages/components/constructor-form/models/config/zen_wallet.mjs +1 -1
  272. package/esm2022/lib/app/pages/components/constructor-form/models/field-template.mjs +1 -1
  273. package/esm2022/lib/app/pages/components/constructor-form/models/index.mjs +1 -1
  274. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field-options.mjs +1 -1
  275. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field-type.enum.mjs +1 -1
  276. package/esm2022/lib/app/pages/components/constructor-form/models/payment-field.mjs +1 -1
  277. package/esm2022/lib/app/pages/components/constructor-form/models/payment-fields.mjs +1 -1
  278. package/esm2022/lib/app/pages/components/constructor-form/models/terminal-step.enum.mjs +1 -1
  279. package/esm2022/lib/app/pages/components/constructor-form/services/constructor-form.service.mjs +1 -7
  280. package/esm2022/lib/app/pages/components/constructor-form/services/index.mjs +1 -1
  281. package/esm2022/lib/app/pages/components/error/error.component.mjs +3 -3
  282. package/esm2022/lib/app/pages/components/index.mjs +1 -1
  283. package/esm2022/lib/app/pages/components/terminal-layout/terminal-layout.component.mjs +17 -4
  284. package/esm2022/lib/app/pages/directives/fee-template.directive.mjs +2 -5
  285. package/esm2022/lib/app/pages/directives/index.mjs +1 -1
  286. package/esm2022/lib/app/pages/directives/input-mask-corrector.directive.mjs +1 -1
  287. package/esm2022/lib/app/pages/directives/tab-index-focus.directive.mjs +1 -1
  288. package/esm2022/lib/app/pages/index.mjs +1 -1
  289. package/esm2022/lib/app/pages/pages.module.mjs +1 -1
  290. package/esm2022/lib/app/pages/services/index.mjs +1 -1
  291. package/esm2022/lib/app/pages/services/mask.service.mjs +1 -1
  292. package/esm2022/lib/app/pipes/countries-sort.pipe.mjs +1 -1
  293. package/esm2022/lib/app/pipes/country-translate.pipe.mjs +1 -1
  294. package/esm2022/lib/app/pipes/currency.pipe.mjs +1 -1
  295. package/esm2022/lib/app/pipes/html-sanitizer.pipe.mjs +1 -1
  296. package/esm2022/lib/app/pipes/index.mjs +1 -1
  297. package/esm2022/lib/app/pipes/method-title.pipe.mjs +1 -1
  298. package/esm2022/lib/app/services/api-errors.service.mjs +1 -1
  299. package/esm2022/lib/app/services/csrf.resolver.mjs +1 -1
  300. package/esm2022/lib/app/services/error.interceptior.mjs +1 -1
  301. package/esm2022/lib/app/services/index.mjs +1 -1
  302. package/esm2022/lib/app/services/local-storage.mjs +1 -1
  303. package/esm2022/lib/app/services/script-loader.mjs +1 -1
  304. package/esm2022/lib/app/services/session.data-source.mjs +5 -18
  305. package/esm2022/lib/app/services/translation/translate-lang-storage.service.mjs +1 -1
  306. package/esm2022/lib/app/shared/components/constructor-status/constructor-status.component.mjs +3 -3
  307. package/esm2022/lib/app/shared/components/index.mjs +1 -1
  308. package/esm2022/lib/app/shared/components/terminal-lang-switcher/terminal-lang-switcher.component.mjs +3 -3
  309. package/esm2022/lib/app/shared/components/terminal-layout-tpl/terminal-layout-tpl.component.mjs +3 -3
  310. package/esm2022/lib/app/shared/components/trm-select/scrollbar-select-height.directive.mjs +1 -1
  311. package/esm2022/lib/app/shared/components/trm-select/trm-select-label-template.directive.mjs +1 -1
  312. package/esm2022/lib/app/shared/components/trm-select/trm-select.component.mjs +3 -3
  313. package/esm2022/lib/app/shared/directives/index.mjs +1 -1
  314. package/esm2022/lib/app/shared/directives/ng-var.directive.mjs +1 -1
  315. package/esm2022/lib/app/shared/index.mjs +1 -1
  316. package/esm2022/lib/app/shared/pipes/index.mjs +1 -1
  317. package/esm2022/lib/app/shared/pipes/sanitizer.pipe.mjs +1 -1
  318. package/esm2022/lib/app/shared/pipes/translate-by-key.pipe.mjs +1 -1
  319. package/esm2022/lib/app/shared/shared.module.mjs +1 -1
  320. package/esm2022/lib/app/terminal-tpl.component.mjs +3 -3
  321. package/esm2022/lib/app/terminal.module.mjs +1 -1
  322. package/esm2022/lib/codegen/api/api.mjs +1 -1
  323. package/esm2022/lib/codegen/api/checkin.service.mjs +1 -1
  324. package/esm2022/lib/codegen/api/configuration.mjs +1 -1
  325. package/esm2022/lib/codegen/api/terminal.service.mjs +1 -1
  326. package/esm2022/lib/codegen/index.mjs +1 -1
  327. package/esm2022/lib/codegen/model/apiErrors.mjs +1 -1
  328. package/esm2022/lib/codegen/model/badRequestResponse.mjs +1 -1
  329. package/esm2022/lib/codegen/model/bank.mjs +1 -1
  330. package/esm2022/lib/codegen/model/documentType.mjs +1 -1
  331. package/esm2022/lib/codegen/model/getCheckinSessionInfo200Response.mjs +1 -1
  332. package/esm2022/lib/codegen/model/getTerminalMethodBanks200Response.mjs +1 -1
  333. package/esm2022/lib/codegen/model/getTerminalMethodDocumentTypes200Response.mjs +1 -1
  334. package/esm2022/lib/codegen/model/invoiceStatus.mjs +1 -1
  335. package/esm2022/lib/codegen/model/methodInfo.mjs +1 -1
  336. package/esm2022/lib/codegen/model/methodInfoLimits.mjs +1 -1
  337. package/esm2022/lib/codegen/model/methodType.mjs +1 -1
  338. package/esm2022/lib/codegen/model/methodTypeType.mjs +1 -1
  339. package/esm2022/lib/codegen/model/models.mjs +1 -1
  340. package/esm2022/lib/codegen/model/postTerminalClose200Response.mjs +1 -1
  341. package/esm2022/lib/codegen/model/postTerminalOpen200Response.mjs +1 -1
  342. package/esm2022/lib/codegen/model/postTerminalOpenRequest.mjs +1 -1
  343. package/esm2022/lib/codegen/model/postTerminalPaymentConfirm200Response.mjs +1 -1
  344. package/esm2022/lib/codegen/model/postTerminalPaymentConfirmRequest.mjs +1 -1
  345. package/esm2022/lib/codegen/model/postTerminalPaymentPrepare200Response.mjs +1 -1
  346. package/esm2022/lib/codegen/model/postTerminalPaymentPrepareRequest.mjs +1 -1
  347. package/esm2022/lib/codegen/model/sessionInfo.mjs +1 -1
  348. package/esm2022/lib/codegen/model/sessionInfoAntiFraudPixel.mjs +1 -1
  349. package/esm2022/lib/const.mjs +1 -1
  350. package/esm2022/lib/helpers/index.mjs +1 -1
  351. package/esm2022/lib/helpers/moment-import.mjs +1 -1
  352. package/esm2022/lib/helpers/remove-empty-props.mjs +1 -1
  353. package/esm2022/lib/index.mjs +1 -1
  354. package/esm2022/public-api.mjs +1 -1
  355. package/fesm2022/trm-tmpl.mjs +51 -60
  356. package/fesm2022/trm-tmpl.mjs.map +1 -1
  357. package/lib/app/pages/components/constructor-form/services/constructor-form.service.d.ts +0 -2
  358. package/lib/app/pages/components/terminal-layout/terminal-layout.component.d.ts +1 -0
  359. package/lib/app/pages/directives/fee-template.directive.d.ts +0 -2
  360. package/lib/app/services/session.data-source.d.ts +0 -1
  361. package/package.json +1 -1
  362. package/scss/base.scss +12 -12
  363. package/scss/btn.scss +50 -50
  364. package/scss/currency.scss +31 -31
  365. package/scss/datepicker.scss +19 -19
  366. package/scss/fonts.scss +18 -18
  367. package/scss/icons.scss +9 -9
  368. package/scss/images.scss +43 -43
  369. package/scss/index.scss +12 -12
  370. package/scss/input.scss +60 -60
  371. package/scss/mixins.scss +193 -193
  372. package/scss/skeleton.scss +68 -68
  373. package/scss/spinner.scss +65 -65
  374. package/scss/theme.scss +33 -33
  375. package/scss/utils.scss +14 -14
  376. package/scss/validation.scss +7 -7
  377. package/scss/variables.scss +1 -1
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { InjectionToken, inject, Injectable, ChangeDetectorRef, CSP_NONCE, NgModule, TemplateRef, Directive, Component, ContentChild, HostListener, ElementRef, Renderer2, Pipe, EventEmitter, forwardRef, ChangeDetectionStrategy, Input, Output, SecurityContext, ViewContainerRef, Injector, DestroyRef, ViewChild, ViewChildren } from '@angular/core';
2
+ import { InjectionToken, inject, Injectable, ChangeDetectorRef, CSP_NONCE, NgModule, Directive, TemplateRef, Component, ContentChild, HostListener, ElementRef, Renderer2, Pipe, EventEmitter, forwardRef, ChangeDetectionStrategy, Input, Output, SecurityContext, ViewContainerRef, Injector, DestroyRef, ViewChild, ViewChildren } from '@angular/core';
3
3
  import * as i1 from '@angular/router';
4
4
  import { RouterModule, Router, NavigationEnd, NavigationCancel, NavigationError, RouterOutlet, ActivatedRoute } from '@angular/router';
5
5
  import { registerLocaleData, DOCUMENT, AsyncPipe, NgTemplateOutlet, NgClass, CommonModule, CurrencyPipe, getCurrencySymbol, Location } from '@angular/common';
@@ -3485,7 +3485,6 @@ class SessionDataSource {
3485
3485
  this.data$ = new BehaviorSubject(undefined);
3486
3486
  this.loading$ = new BehaviorSubject(true);
3487
3487
  this.loadingMethodInfo$ = new BehaviorSubject(true);
3488
- this.loadingConfirm$ = new BehaviorSubject(null);
3489
3488
  this.configurations = new Map();
3490
3489
  this.feeChangeable = !!this.terminalApi.getFee;
3491
3490
  }
@@ -3566,7 +3565,7 @@ class SessionDataSource {
3566
3565
  }));
3567
3566
  }
3568
3567
  getMethodInfo(currency, typeId) {
3569
- if (this.loadingMethodInfo$.getValue() !== null) {
3568
+ if (!this.loadingMethodInfo$.getValue()) {
3570
3569
  this.loadingMethodInfo$.next(true);
3571
3570
  }
3572
3571
  if (!typeId || !currency) {
@@ -3585,7 +3584,6 @@ class SessionDataSource {
3585
3584
  this.payment_token = method.payment_token;
3586
3585
  }
3587
3586
  this.loadingMethodInfo$.next(false);
3588
- this.loadingConfirm$.next(false);
3589
3587
  }));
3590
3588
  }
3591
3589
  catchError(loading$) {
@@ -3597,20 +3595,14 @@ class SessionDataSource {
3597
3595
  };
3598
3596
  }
3599
3597
  prepare(data) {
3600
- if (!this.loadingConfirm$.getValue()) {
3601
- this.loadingConfirm$.next(true);
3602
- }
3603
3598
  return this.terminalApi
3604
3599
  .postTerminalPaymentPrepare({
3605
3600
  token: this.token,
3606
3601
  terminalPaymentPrepareRequest: data
3607
3602
  })
3608
- .pipe(delay(2000), catchError(this.catchError(this.loadingConfirm$)), tap(() => this.loadingConfirm$.next(false)));
3603
+ .pipe(delay(2000), catchError(this.catchError()));
3609
3604
  }
3610
3605
  confirm() {
3611
- if (!this.loadingConfirm$.getValue()) {
3612
- this.loadingConfirm$.next(true);
3613
- }
3614
3606
  return this.terminalApi
3615
3607
  .postTerminalPaymentConfirm({
3616
3608
  token: this.token,
@@ -3619,24 +3611,19 @@ class SessionDataSource {
3619
3611
  gaCookie: this.cookieSrv.get('_ga') || null
3620
3612
  }
3621
3613
  })
3622
- .pipe(catchError(this.catchError(this.loadingConfirm$)), tap((resp) => {
3614
+ .pipe(catchError(this.catchError()), tap((resp) => {
3623
3615
  this.redirectUrl = resp.redirectUrl;
3624
- this.loadingConfirm$.next(false);
3625
3616
  }));
3626
3617
  }
3627
3618
  close() {
3628
- if (!this.loadingConfirm$.getValue()) {
3629
- this.loadingConfirm$.next(true);
3630
- }
3631
3619
  return this.terminalApi
3632
3620
  .postTerminalClose({
3633
3621
  token: this.token
3634
3622
  })
3635
- .pipe(catchError(this.catchError(this.loadingConfirm$)), map(() => {
3623
+ .pipe(catchError(this.catchError()), map(() => {
3636
3624
  if (!this.returnBack()) {
3637
3625
  const error = { code: I18N_KEY.SESSION_CLOSED };
3638
3626
  this.apiErrorsSrv.setLocalError(error);
3639
- this.loadingConfirm$?.next(false);
3640
3627
  this.cd.markForCheck();
3641
3628
  throw error;
3642
3629
  }
@@ -3799,9 +3786,6 @@ const provideTerminal = () => {
3799
3786
  };
3800
3787
 
3801
3788
  class FeeTemplateDirective {
3802
- constructor() {
3803
- this.tml = inject(TemplateRef);
3804
- }
3805
3789
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: FeeTemplateDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
3806
3790
  static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: FeeTemplateDirective, isStandalone: true, selector: "[terminalFee]", ngImport: i0 }); }
3807
3791
  }
@@ -3843,13 +3827,13 @@ class TerminalTplComponent {
3843
3827
  this.unSubscriber.unsubscribe();
3844
3828
  }
3845
3829
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalTplComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
3846
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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) {\r\n <div class=\"app__container\">\r\n <router-outlet></router-outlet>\r\n </div>\r\n}\r\n", styles: [""], dependencies: [{ kind: "directive", type: RouterOutlet, selector: "router-outlet", inputs: ["name"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "pipe", type: AsyncPipe, name: "async" }] }); }
3830
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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"], outputs: ["activate", "deactivate", "attach", "detach"], exportAs: ["outlet"] }, { kind: "pipe", type: AsyncPipe, name: "async" }] }); }
3847
3831
  }
3848
3832
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalTplComponent, decorators: [{
3849
3833
  type: Component,
3850
3834
  args: [{ selector: 'terminal', host: {
3851
3835
  class: 'trm'
3852
- }, standalone: true, imports: [RouterOutlet, AsyncPipe], template: "@if (ready$ | async) {\r\n <div class=\"app__container\">\r\n <router-outlet></router-outlet>\r\n </div>\r\n}\r\n" }]
3836
+ }, standalone: true, imports: [RouterOutlet, AsyncPipe], template: "@if (ready$ | async) {\n <div class=\"app__container\">\n <router-outlet></router-outlet>\n </div>\n}\n" }]
3853
3837
  }], propDecorators: { feeTpl: [{
3854
3838
  type: ContentChild,
3855
3839
  args: [FeeTemplateDirective, { read: TemplateRef, static: false }]
@@ -4114,7 +4098,7 @@ class TrmSelectComponent {
4114
4098
  useExisting: forwardRef(() => TrmSelectComponent),
4115
4099
  multi: true,
4116
4100
  }
4117
- ], 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)}.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{-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;--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)}@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
+ ], 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)}.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{-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;--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)}@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 }); }
4118
4102
  }
4119
4103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TrmSelectComponent, decorators: [{
4120
4104
  type: Component,
@@ -4124,7 +4108,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
4124
4108
  useExisting: forwardRef(() => TrmSelectComponent),
4125
4109
  multi: true,
4126
4110
  }
4127
- ], animations: [insertRemoveTrigger], standalone: true, 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)}.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{-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;--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)}@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
+ ], animations: [insertRemoveTrigger], standalone: true, 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)}.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{-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;--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)}@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"] }]
4128
4112
  }], ctorParameters: () => [], propDecorators: { label: [{
4129
4113
  type: Input
4130
4114
  }], hasBorder: [{
@@ -4186,11 +4170,11 @@ class TerminalLangSwitcherComponent {
4186
4170
  this.unSubscriber.unsubscribe();
4187
4171
  }
4188
4172
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalLangSwitcherComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4189
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: TerminalLangSwitcherComponent, isStandalone: true, selector: "app-terminal-lang-switcher", inputs: { loading: "loading", tabIndex: "tabIndex" }, outputs: { langChange: "langChange" }, ngImport: i0, template: "@if (!loading) {\r\n <app-trm-select class=\"lang-switcher\"\r\n [hasBorder]=\"false\"\r\n [searchable]=\"false\"\r\n [hasScrollbar]=\"false\"\r\n [data]=\"langs\"\r\n [ngModel]=\"lang\"\r\n [tabIndex]=\"tabIndex\"\r\n (ngModelChange)=\"changeLang($event)\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\" [ngClass]=\"'fi-' + translation_keys[item].code\"></span>\r\n <span> {{translation_keys[item].name | translate}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n} @else {\r\n <gm-skeleton [count]=\"1\" [size]=\"30\"></gm-skeleton>\r\n}\r\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
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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 }); }
4190
4174
  }
4191
4175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalLangSwitcherComponent, decorators: [{
4192
4176
  type: Component,
4193
- args: [{ selector: 'app-terminal-lang-switcher', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [TrmSelectComponent, FormsModule, TrmSelectLabelTemplateDirective, NgClass, TranslateModule, GmSkeletonComponent], template: "@if (!loading) {\r\n <app-trm-select class=\"lang-switcher\"\r\n [hasBorder]=\"false\"\r\n [searchable]=\"false\"\r\n [hasScrollbar]=\"false\"\r\n [data]=\"langs\"\r\n [ngModel]=\"lang\"\r\n [tabIndex]=\"tabIndex\"\r\n (ngModelChange)=\"changeLang($event)\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\" [ngClass]=\"'fi-' + translation_keys[item].code\"></span>\r\n <span> {{translation_keys[item].name | translate}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n} @else {\r\n <gm-skeleton [count]=\"1\" [size]=\"30\"></gm-skeleton>\r\n}\r\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
+ args: [{ selector: 'app-terminal-lang-switcher', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, 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"] }]
4194
4178
  }], ctorParameters: () => [], propDecorators: { loading: [{
4195
4179
  type: Input
4196
4180
  }], langChange: [{
@@ -4228,11 +4212,11 @@ class TerminalLayoutTplComponent {
4228
4212
  this.unSubscriber.unsubscribe();
4229
4213
  }
4230
4214
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalLayoutTplComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4231
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: TerminalLayoutTplComponent, isStandalone: true, selector: "app-terminal-layout-tpl", inputs: { projectName: "projectName", description: "description", loading: "loading" }, ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\r\n <div class=\"terminal-layout\">\r\n <section class=\"terminal\">\r\n <div class=\"terminal__content\">\r\n <header class=\"terminal__header\">\r\n <i class=\"terminal__header-logo\"\r\n [class]=\"logoClass\"></i>\r\n <div class=\"terminal__header-lang\">\r\n @if (hasChoice) {\r\n <app-terminal-lang-switcher\r\n [loading]=\"loading\"\r\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\r\n }\r\n </div>\r\n </header>\r\n <div class=\"terminal__form\">\r\n <ng-content selector=\"[terminal-layout-status]\"></ng-content>\r\n <ng-content selector=\"[terminal-layout-form]\"></ng-content>\r\n @if (loading) {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\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 </div>\r\n </div>\r\n </section>\r\n <footer class=\"terminal-footer\">\r\n <i class=\"terminal-footer__logo\"></i>\r\n <p class=\"terminal-footer__txt\">\r\n {{footerText}}\r\n </p>\r\n </footer>\r\n </div>\r\n</ng-scrollbar>\r\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"] }] }); }
4215
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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"] }] }); }
4232
4216
  }
4233
4217
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalLayoutTplComponent, decorators: [{
4234
4218
  type: Component,
4235
- args: [{ selector: 'app-terminal-layout-tpl', standalone: true, imports: [NgScrollbar, TerminalLangSwitcherComponent, GmSkeletonComponent], template: "<ng-scrollbar appearance=\"compact\">\r\n <div class=\"terminal-layout\">\r\n <section class=\"terminal\">\r\n <div class=\"terminal__content\">\r\n <header class=\"terminal__header\">\r\n <i class=\"terminal__header-logo\"\r\n [class]=\"logoClass\"></i>\r\n <div class=\"terminal__header-lang\">\r\n @if (hasChoice) {\r\n <app-terminal-lang-switcher\r\n [loading]=\"loading\"\r\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\r\n }\r\n </div>\r\n </header>\r\n <div class=\"terminal__form\">\r\n <ng-content selector=\"[terminal-layout-status]\"></ng-content>\r\n <ng-content selector=\"[terminal-layout-form]\"></ng-content>\r\n @if (loading) {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\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 </div>\r\n </div>\r\n </section>\r\n <footer class=\"terminal-footer\">\r\n <i class=\"terminal-footer__logo\"></i>\r\n <p class=\"terminal-footer__txt\">\r\n {{footerText}}\r\n </p>\r\n </footer>\r\n </div>\r\n</ng-scrollbar>\r\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"] }]
4219
+ args: [{ selector: 'app-terminal-layout-tpl', standalone: true, 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"] }]
4236
4220
  }], ctorParameters: () => [], propDecorators: { projectName: [{
4237
4221
  type: Input
4238
4222
  }], description: [{
@@ -4273,11 +4257,11 @@ class ConstructorStatusComponent {
4273
4257
  return this.versionSrv.supportEmail;
4274
4258
  }
4275
4259
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorStatusComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
4276
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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\">\r\n <div class=\"c-status__content\"\r\n [class.c-status--failed]=\"failed\"\r\n [class.c-status--progress]=\"inProgress\"\r\n [class.c-status--live]=\"animation\"\r\n >\r\n <i class=\"c-status__img\"></i>\r\n <h5 class=\"c-status__title\">\r\n @if (inProgress) {\r\n {{ progressTitle || (I18N_KEY.PROGRESS_TITLE | trans) }}\r\n } @else {\r\n @if (failed) {\r\n {{ failTitle || (I18N_KEY.TERMINAL_SESSION_BREAK | trans) }}\r\n }\r\n @if (!failed) {\r\n {{ successTitle || (I18N_KEY.TERMINAL_SESSION_SUCCESS | trans) }}\r\n }\r\n }\r\n </h5>\r\n <div class=\"c-status__msg\" [innerHTML]=\"message | sanitize: SecurityContext.HTML\"> {{ message }}</div>\r\n @if (hasSupportHint) {\r\n <div class=\"c-status__hint\">\r\n {{ I18N_KEY.TERMINAL_SESSION_SUPPORT | trans }}:\r\n @if (supportEmail) {\r\n <a [href]=\"'mailto:' + supportEmail\"> {{ supportEmail }} </a>\r\n }\r\n </div>\r\n }\r\n </div>\r\n @if (!!backUrl) {\r\n <div class=\"c-status__actions\">\r\n <a class=\"trm-button trm-button--primary\"\r\n [tabindex]=\"tabIndex\"\r\n [href]=\"backUrl | sanitize: SecurityContext.URL\"> {{ backUrlTitle || (I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans) }}</a>\r\n <div class=\"c-status__hint c-status__hint-button\">\r\n <ng-content constructor-status-button-hint></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\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 }); }
4260
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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 | sanitize: SecurityContext.HTML\"> {{ 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 }); }
4277
4261
  }
4278
4262
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorStatusComponent, decorators: [{
4279
4263
  type: Component,
4280
- args: [{ selector: 'app-constructor-status', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [SanitizerPipe, TranslateByKeyPipe], template: "<div class=\"c-status\">\r\n <div class=\"c-status__content\"\r\n [class.c-status--failed]=\"failed\"\r\n [class.c-status--progress]=\"inProgress\"\r\n [class.c-status--live]=\"animation\"\r\n >\r\n <i class=\"c-status__img\"></i>\r\n <h5 class=\"c-status__title\">\r\n @if (inProgress) {\r\n {{ progressTitle || (I18N_KEY.PROGRESS_TITLE | trans) }}\r\n } @else {\r\n @if (failed) {\r\n {{ failTitle || (I18N_KEY.TERMINAL_SESSION_BREAK | trans) }}\r\n }\r\n @if (!failed) {\r\n {{ successTitle || (I18N_KEY.TERMINAL_SESSION_SUCCESS | trans) }}\r\n }\r\n }\r\n </h5>\r\n <div class=\"c-status__msg\" [innerHTML]=\"message | sanitize: SecurityContext.HTML\"> {{ message }}</div>\r\n @if (hasSupportHint) {\r\n <div class=\"c-status__hint\">\r\n {{ I18N_KEY.TERMINAL_SESSION_SUPPORT | trans }}:\r\n @if (supportEmail) {\r\n <a [href]=\"'mailto:' + supportEmail\"> {{ supportEmail }} </a>\r\n }\r\n </div>\r\n }\r\n </div>\r\n @if (!!backUrl) {\r\n <div class=\"c-status__actions\">\r\n <a class=\"trm-button trm-button--primary\"\r\n [tabindex]=\"tabIndex\"\r\n [href]=\"backUrl | sanitize: SecurityContext.URL\"> {{ backUrlTitle || (I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans) }}</a>\r\n <div class=\"c-status__hint c-status__hint-button\">\r\n <ng-content constructor-status-button-hint></ng-content>\r\n </div>\r\n </div>\r\n }\r\n</div>\r\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"] }]
4264
+ args: [{ selector: 'app-constructor-status', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, 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 | sanitize: SecurityContext.HTML\"> {{ 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"] }]
4281
4265
  }], propDecorators: { failed: [{
4282
4266
  type: Input
4283
4267
  }], inProgress: [{
@@ -4431,12 +4415,6 @@ class ConstructorFormService extends FormGroup {
4431
4415
  get methodInfoLoading() {
4432
4416
  return this.sessionDS.loadingMethodInfo$.getValue();
4433
4417
  }
4434
- continueLoaderOn() {
4435
- this.sessionDS.loadingConfirm$.next(true);
4436
- }
4437
- continueLoaderOff() {
4438
- this.sessionDS.loadingConfirm$.next(false);
4439
- }
4440
4418
  get paymentFormFieldNames() {
4441
4419
  return Object.keys(this.payment.controls);
4442
4420
  }
@@ -4972,7 +4950,7 @@ class ConstructorFieldIframeComponent {
4972
4950
  multi: true,
4973
4951
  },
4974
4952
  CardSdkService,
4975
- ], hostDirectives: [{ directive: IframeValidatorDirectiveDirective }], ngImport: i0, template: "@if (!status) {\r\n <div\r\n class=\"iframe-container\"\r\n [id]=\"ID_CDE_CONTAINER\"\r\n [hidden]=\"loading\"\r\n [class.iframe-container--ready]=\"viewReady\"\r\n ></div>\r\n} @else if (!loading) {\r\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\r\n}\r\n\r\n@if (loading) {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of [1,2]; track i) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n}\r\n", styles: [":host{position:relative}.iframe-container{position:absolute;width:100%;visibility:hidden}.iframe-container--ready{position:relative;visibility:visible}.iframe-warning{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}\n"], dependencies: [{ kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "component", type: GmSkeletonComponent, selector: "gm-skeleton", inputs: ["shape", "orientation", "count", "size", "gap"] }], animations: [insertRemoveTrigger], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
4953
+ ], 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 }); }
4976
4954
  }
4977
4955
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldIframeComponent, decorators: [{
4978
4956
  type: Component,
@@ -4987,7 +4965,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
4987
4965
  {
4988
4966
  directive: IframeValidatorDirectiveDirective,
4989
4967
  },
4990
- ], template: "@if (!status) {\r\n <div\r\n class=\"iframe-container\"\r\n [id]=\"ID_CDE_CONTAINER\"\r\n [hidden]=\"loading\"\r\n [class.iframe-container--ready]=\"viewReady\"\r\n ></div>\r\n} @else if (!loading) {\r\n <p class=\"iframe-warning text--warn\">{{ status | trans }}</p>\r\n}\r\n\r\n@if (loading) {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of [1,2]; track i) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n}\r\n", styles: [":host{position:relative}.iframe-container{position:absolute;width:100%;visibility:hidden}.iframe-container--ready{position:relative;visibility:visible}.iframe-warning{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}\n"] }]
4968
+ ], 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"] }]
4991
4969
  }], propDecorators: { tabIndex: [{
4992
4970
  type: Input
4993
4971
  }] } });
@@ -5120,7 +5098,7 @@ class PsSelectComponent {
5120
5098
  },
5121
5099
  MethodTitlePipe,
5122
5100
  TranslatePipe
5123
- ], ngImport: i0, template: "<label class=\"trm-label\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\r\n</label>\r\n<ul class=\"methods\">\r\n @for (method of popularMethods; track method.id) {\r\n <li class=\"method\"\r\n [class.method--selected]=\"selectedType === method.id\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\r\n (blur)=\"onTouch()\"\r\n (click)=\"selectMethod(method.id)\"\r\n >\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+method.name\"\r\n ></span>\r\n <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\r\n </li>\r\n }\r\n @if (searchString || otherMethods.length) {\r\n <li class=\"methods__other\">\r\n <app-trm-select [data]=\"otherMethods\"\r\n idLabel=\"method\"\r\n (search)=\"search($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"otherMethodControl\"\r\n [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\r\n class=\"c-field-select trm-form-field\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+item.name\"></span>\r\n <span class=\"method__name\"\r\n [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </li>\r\n }\r\n</ul>\r\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\r\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\r\n\r\n", styles: [":host{display:block}.methods{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:flex-start;list-style:none;flex-wrap:wrap;margin:0;padding:0}.methods .method{--method-color: var(--ps-select-color, var(--color-base-350));--method-border-color: var(--ps-select-border-color, var(--color-base-200));display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start;box-sizing:border-box;flex:100%;max-width:calc(50% - 5px);padding:16px;border:1px solid var(--method-border-color);border-radius:10px;outline:0;align-self:stretch}.methods .method:hover,.methods .method:focus{--method-color: var(--ps-select-color--hover, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--hover, var(--color-primary-500));cursor:pointer;box-shadow:0 0 15px -1px #a378ff26}.methods .method.method--selected{--method-color: var(--ps-select-color--active, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--active, var(--color-primary-500));cursor:default;box-shadow:0 0 0 2px var(--method-border-color);outline:none}.methods .method__icon{background:transparent no-repeat 100% 100%;background-size:contain;width:24px;height:24px;flex-shrink:0}.methods .method__name{font-weight:600;font-size:14px;line-height:18px;color:var(--method-color);white-space:normal;overflow:hidden;max-width:100%;text-overflow:ellipsis;flex-shrink:0}.methods__other{box-sizing:border-box;flex:100%;margin-top:10px}\n"], 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 }); }
5101
+ ], 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 }); }
5124
5102
  }
5125
5103
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: PsSelectComponent, decorators: [{
5126
5104
  type: Component,
@@ -5132,7 +5110,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
5132
5110
  },
5133
5111
  MethodTitlePipe,
5134
5112
  TranslatePipe
5135
- ], standalone: true, imports: [TabIndexFocusDirective, NgClass, TrmSelectComponent, FormsModule, ReactiveFormsModule, TrmSelectLabelTemplateDirective, MethodTitlePipe, TranslateByKeyPipe], template: "<label class=\"trm-label\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}}\r\n</label>\r\n<ul class=\"methods\">\r\n @for (method of popularMethods; track method.id) {\r\n <li class=\"method\"\r\n [class.method--selected]=\"selectedType === method.id\"\r\n [tabindex]=\"tabIndex\"\r\n (keydown.enter)=\"$event.stopPropagation(); selectMethod(method.id)\"\r\n (blur)=\"onTouch()\"\r\n (click)=\"selectMethod(method.id)\"\r\n >\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+method.name\"\r\n ></span>\r\n <span class=\"method__name\" [title]=\"method.name | trans\" > {{method.name | method_title | trans}} </span>\r\n </li>\r\n }\r\n @if (searchString || otherMethods.length) {\r\n <li class=\"methods__other\">\r\n <app-trm-select [data]=\"otherMethods\"\r\n idLabel=\"method\"\r\n (search)=\"search($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"otherMethodControl\"\r\n [placeholder]=\"I18N_KEY.CONSTRUCTOR_PLACEHOLDER_PS | trans\"\r\n class=\"c-field-select trm-form-field\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"method__icon\"\r\n [ngClass]=\"'ps-icon-'+item.name\"></span>\r\n <span class=\"method__name\"\r\n [title]=\"item.name | trans\" >{{item.name | method_title | trans}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </li>\r\n }\r\n</ul>\r\n<ng-content select=\"[app-ps-select-hint]\"></ng-content>\r\n<ng-content select=\"[app-ps-select-error]\"></ng-content>\r\n\r\n", styles: [":host{display:block}.methods{display:flex;flex-direction:row;gap:10px;justify-content:flex-start;align-items:flex-start;list-style:none;flex-wrap:wrap;margin:0;padding:0}.methods .method{--method-color: var(--ps-select-color, var(--color-base-350));--method-border-color: var(--ps-select-border-color, var(--color-base-200));display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start;box-sizing:border-box;flex:100%;max-width:calc(50% - 5px);padding:16px;border:1px solid var(--method-border-color);border-radius:10px;outline:0;align-self:stretch}.methods .method:hover,.methods .method:focus{--method-color: var(--ps-select-color--hover, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--hover, var(--color-primary-500));cursor:pointer;box-shadow:0 0 15px -1px #a378ff26}.methods .method.method--selected{--method-color: var(--ps-select-color--active, var(--color-primary-500));--method-border-color: var(--ps-select-border-color--active, var(--color-primary-500));cursor:default;box-shadow:0 0 0 2px var(--method-border-color);outline:none}.methods .method__icon{background:transparent no-repeat 100% 100%;background-size:contain;width:24px;height:24px;flex-shrink:0}.methods .method__name{font-weight:600;font-size:14px;line-height:18px;color:var(--method-color);white-space:normal;overflow:hidden;max-width:100%;text-overflow:ellipsis;flex-shrink:0}.methods__other{box-sizing:border-box;flex:100%;margin-top:10px}\n"] }]
5113
+ ], standalone: true, 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"] }]
5136
5114
  }], propDecorators: { methods: [{
5137
5115
  type: Input
5138
5116
  }], tabIndex: [{
@@ -5192,7 +5170,7 @@ class ConstructorFieldSelectComponent {
5192
5170
  useExisting: forwardRef(() => ConstructorFieldSelectComponent),
5193
5171
  multi: true
5194
5172
  }
5195
- ], ngImport: i0, template: "@if (control) {\r\n <app-trm-select [data]=\"data\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n [label]=\"config.label | trans\"\r\n [name]=\"config.name\"\r\n (search)=\"search($event)\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n [tabIndex]=\"tabIndex\"\r\n class=\"c-field-select trm-form-field\"\r\n ></app-trm-select>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n\r\n}\r\n", styles: [":host{display:block;width:100%}\n"], dependencies: [{ kind: "component", type: TrmSelectComponent, selector: "app-trm-select", inputs: ["label", "hasBorder", "data", "tabIndex", "name", "placeholder", "searchable", "hasScrollbar", "nameId", "nameLabel"], outputs: ["open", "search"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$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 }); }
5173
+ ], 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 }); }
5196
5174
  }
5197
5175
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldSelectComponent, decorators: [{
5198
5176
  type: Component,
@@ -5202,7 +5180,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
5202
5180
  useExisting: forwardRef(() => ConstructorFieldSelectComponent),
5203
5181
  multi: true
5204
5182
  }
5205
- ], standalone: true, imports: [TrmSelectComponent, FormsModule, ReactiveFormsModule, TranslateByKeyPipe], template: "@if (control) {\r\n <app-trm-select [data]=\"data\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n [label]=\"config.label | trans\"\r\n [name]=\"config.name\"\r\n (search)=\"search($event)\"\r\n (open)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n [tabIndex]=\"tabIndex\"\r\n class=\"c-field-select trm-form-field\"\r\n ></app-trm-select>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n\r\n}\r\n", styles: [":host{display:block;width:100%}\n"] }]
5183
+ ], standalone: true, 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"] }]
5206
5184
  }], propDecorators: { config: [{
5207
5185
  type: Input
5208
5186
  }], items: [{
@@ -5406,7 +5384,7 @@ class ConstructorFieldTextComponent {
5406
5384
  useExisting: forwardRef(() => ConstructorFieldTextComponent),
5407
5385
  multi: true
5408
5386
  }
5409
- ], viewQueries: [{ propertyName: "dir", first: true, predicate: NgxMaskDirective, descendants: true }], ngImport: i0, template: "@if (control) {\r\n <label class=\"trm-label\"\r\n [for]=\"config.name\"\r\n > {{ config.label | trans }} </label>\r\n <div class=\"input-wrapper trm-form-field-wrapper c-text\"\r\n [class.c-text--disabled]=\"disabled\"\r\n [class.c-text--uppercase]=\"config.uppercase\">\r\n @if (!matDatepicker) {\r\n <input\r\n class=\"trm-form-field trm-input\"\r\n [class.trm-form-field--disabled]=\"disabled\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n (blur)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n (input)=\"onInput($event)\"\r\n (paste)=\"onPaste($event)\"\r\n [type]=\"type\"\r\n [name]=\"name\"\r\n [id]=\"name\"\r\n [mask]=\"mask\"\r\n [attr.inputmode]=\"inputmode\"\r\n [patterns]=\"maskPatterns\"\r\n [allowNegativeNumbers]=\"false\"\r\n [thousandSeparator]=\"' '\"\r\n [decimalMarker]=\"'.'\"\r\n [validation]=\"config.maskValidation || false\"\r\n [specialCharacters]=\"specialCharacters\"\r\n [dropSpecialCharacters]=\"dropSpecialCharacters\"\r\n [tabindex]=\"tabIndex\"\r\n />\r\n } @else {\r\n <input class=\"trm-form-field trm-input\"\r\n [matDatepicker]=\"matDatepicker\"\r\n [formControl]=\"control\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n (input)=\"onDateInput($event)\"\r\n [attr.inputmode]=\"inputmode\"\r\n (blur)=\"onTouch()\"\r\n [min]=\"config?.options?.min\"\r\n [max]=\"config?.options?.max\"\r\n [tabindex]=\"tabIndex\"\r\n type=\"text\"\r\n [name]=\"name\"\r\n [id]=\"name\"\r\n />\r\n }\r\n <ng-content select=\"[app-c-text-suffix]\"></ng-content>\r\n </div>\r\n @if (config.description) {\r\n <div class=\"c-text__hint\"\r\n [innerHTML]=\"config.description | trans\"></div>\r\n }\r\n <ng-content select=\"[app-c-text-hint]\"></ng-content>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('email') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_EMAIL | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('min') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_MIN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('max') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_MAX | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('pattern') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('mask') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n}\r\n", 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", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], 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 }); }
5387
+ ], 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", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], 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 }); }
5410
5388
  }
5411
5389
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldTextComponent, decorators: [{
5412
5390
  type: Component,
@@ -5416,7 +5394,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
5416
5394
  useExisting: forwardRef(() => ConstructorFieldTextComponent),
5417
5395
  multi: true
5418
5396
  }
5419
- ], standalone: true, imports: [FormsModule, NgxMaskDirective, InputMaskCorrector, ReactiveFormsModule, TabIndexFocusDirective, MatDatepickerInput, TranslateByKeyPipe], template: "@if (control) {\r\n <label class=\"trm-label\"\r\n [for]=\"config.name\"\r\n > {{ config.label | trans }} </label>\r\n <div class=\"input-wrapper trm-form-field-wrapper c-text\"\r\n [class.c-text--disabled]=\"disabled\"\r\n [class.c-text--uppercase]=\"config.uppercase\">\r\n @if (!matDatepicker) {\r\n <input\r\n class=\"trm-form-field trm-input\"\r\n [class.trm-form-field--disabled]=\"disabled\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n (blur)=\"onTouch()\"\r\n [formControl]=\"control\"\r\n (input)=\"onInput($event)\"\r\n (paste)=\"onPaste($event)\"\r\n [type]=\"type\"\r\n [name]=\"name\"\r\n [id]=\"name\"\r\n [mask]=\"mask\"\r\n [attr.inputmode]=\"inputmode\"\r\n [patterns]=\"maskPatterns\"\r\n [allowNegativeNumbers]=\"false\"\r\n [thousandSeparator]=\"' '\"\r\n [decimalMarker]=\"'.'\"\r\n [validation]=\"config.maskValidation || false\"\r\n [specialCharacters]=\"specialCharacters\"\r\n [dropSpecialCharacters]=\"dropSpecialCharacters\"\r\n [tabindex]=\"tabIndex\"\r\n />\r\n } @else {\r\n <input class=\"trm-form-field trm-input\"\r\n [matDatepicker]=\"matDatepicker\"\r\n [formControl]=\"control\"\r\n [placeholder]=\"config.placeholder | trans\"\r\n (input)=\"onDateInput($event)\"\r\n [attr.inputmode]=\"inputmode\"\r\n (blur)=\"onTouch()\"\r\n [min]=\"config?.options?.min\"\r\n [max]=\"config?.options?.max\"\r\n [tabindex]=\"tabIndex\"\r\n type=\"text\"\r\n [name]=\"name\"\r\n [id]=\"name\"\r\n />\r\n }\r\n <ng-content select=\"[app-c-text-suffix]\"></ng-content>\r\n </div>\r\n @if (config.description) {\r\n <div class=\"c-text__hint\"\r\n [innerHTML]=\"config.description | trans\"></div>\r\n }\r\n <ng-content select=\"[app-c-text-hint]\"></ng-content>\r\n @if (control.hasError('required') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('email') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_EMAIL | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('min') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_MIN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('max') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_MAX | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('pattern') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('mask') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerParse') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ I18N_KEY.VALIDATION_PATTERN | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerMin') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ (I18N_KEY.VALIDATION_DATE_MIN | trans) + ' ' + control.getError('matDatepickerMin').min.format(FORMAT_DATE) }}\r\n </div>\r\n }\r\n @if (control.hasError('matDatepickerMax') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ (I18N_KEY.VALIDATION_DATE_MAX | trans) + ' ' + control.getError('matDatepickerMax').max.format(FORMAT_DATE) }}\r\n </div>\r\n }\r\n @if (control.hasError('error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ apiError | trans }}\r\n </div>\r\n }\r\n @if (control.hasError('custom_error') && control.touched && control.dirty) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ control.getError('custom_error') | trans }}\r\n </div>\r\n }\r\n}\r\n", 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"] }]
5397
+ ], standalone: true, 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"] }]
5420
5398
  }], ctorParameters: () => [], propDecorators: { config: [{
5421
5399
  type: Input
5422
5400
  }], matDatepicker: [{
@@ -5495,13 +5473,13 @@ class MethodAmountHintComponent {
5495
5473
  return this.mainTpl.feeTpl;
5496
5474
  }
5497
5475
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: MethodAmountHintComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5498
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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>\r\n @if (loading) {\r\n <span class=\"trm-spinner\" @insertRemove></span>\r\n }\r\n @if (options.fee || options.fixedFee) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_FEE | trans) }}\r\n @if (options.fee) {\r\n <span class=\"trm-amount\">\r\n <span class=\"trm-amount__value\">{{ options.fee }}<span class=\"trm-currency\">%</span></span>\r\n </span>\r\n }\r\n @if (options.fixedFee && options.fee) {\r\n <span> + </span>\r\n }\r\n @if (options.fixedFee) {\r\n <span\r\n [innerHTML]=\"options.fixedFee | trm_currency: options.currency | sanitizeHtml\"></span>\r\n }\r\n @if (options.minFixedFee) {\r\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<span\r\n [innerHTML]=\"options.minFixedFee | trm_currency: options.currency | sanitizeHtml\"></span>)\r\n }\r\n </div>\r\n }\r\n @if (options.min) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\r\n <span [innerHTML]=\"options.min | trm_currency: options.currency\"></span>\r\n </div>\r\n }\r\n @if (options.max) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\r\n <span [innerHTML]=\"options.max | trm_currency: options.currency\"></span>\r\n </div>\r\n }\r\n\r\n @if (feeTpl) {\r\n <div *ngTemplateOutlet=\"feeTpl; context: {options}\" @insertRemove></div>\r\n }\r\n</div>\r\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: TrmCurrencyPipe, name: "trm_currency" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "pipe", type: HtmlSanitizerPipe, name: "sanitizeHtml" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [insertRemoveTrigger] }); }
5476
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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 <span\n [innerHTML]=\"options.fixedFee | trm_currency: options.currency | sanitizeHtml\"></span>\n }\n @if (options.minFixedFee) {\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<span\n [innerHTML]=\"options.minFixedFee | trm_currency: options.currency | sanitizeHtml\"></span>)\n }\n </div>\n }\n @if (options.min) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\n <span [innerHTML]=\"options.min | trm_currency: options.currency\"></span>\n </div>\n }\n @if (options.max) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\n <span [innerHTML]=\"options.max | trm_currency: options.currency\"></span>\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: TrmCurrencyPipe, name: "trm_currency" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }, { kind: "pipe", type: HtmlSanitizerPipe, name: "sanitizeHtml" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], animations: [insertRemoveTrigger] }); }
5499
5477
  }
5500
5478
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: MethodAmountHintComponent, decorators: [{
5501
5479
  type: Component,
5502
5480
  args: [{ selector: 'app-method-amount-hint', standalone: true, animations: [insertRemoveTrigger], providers: [CurrencyPipe], imports: [TrmCurrencyPipe, TranslateByKeyPipe, HtmlSanitizerPipe, NgTemplateOutlet], host: {
5503
5481
  '[hidden]': '!loading && (!options || (!options.fee && !options.fixedFee && !options.minFixedFee && !options.min && !options.max))'
5504
- }, template: "<div class=\"c-method-hint\" @insertRemove>\r\n @if (loading) {\r\n <span class=\"trm-spinner\" @insertRemove></span>\r\n }\r\n @if (options.fee || options.fixedFee) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_FEE | trans) }}\r\n @if (options.fee) {\r\n <span class=\"trm-amount\">\r\n <span class=\"trm-amount__value\">{{ options.fee }}<span class=\"trm-currency\">%</span></span>\r\n </span>\r\n }\r\n @if (options.fixedFee && options.fee) {\r\n <span> + </span>\r\n }\r\n @if (options.fixedFee) {\r\n <span\r\n [innerHTML]=\"options.fixedFee | trm_currency: options.currency | sanitizeHtml\"></span>\r\n }\r\n @if (options.minFixedFee) {\r\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<span\r\n [innerHTML]=\"options.minFixedFee | trm_currency: options.currency | sanitizeHtml\"></span>)\r\n }\r\n </div>\r\n }\r\n @if (options.min) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\r\n <span [innerHTML]=\"options.min | trm_currency: options.currency\"></span>\r\n </div>\r\n }\r\n @if (options.max) {\r\n <div @insertRemove>\r\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\r\n <span [innerHTML]=\"options.max | trm_currency: options.currency\"></span>\r\n </div>\r\n }\r\n\r\n @if (feeTpl) {\r\n <div *ngTemplateOutlet=\"feeTpl; context: {options}\" @insertRemove></div>\r\n }\r\n</div>\r\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"] }]
5482
+ }, 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 <span\n [innerHTML]=\"options.fixedFee | trm_currency: options.currency | sanitizeHtml\"></span>\n }\n @if (options.minFixedFee) {\n ({{ I18N_KEY.CONSTRUCTOR_LABEL_MIN_FIXED_FEE | trans }}<span\n [innerHTML]=\"options.minFixedFee | trm_currency: options.currency | sanitizeHtml\"></span>)\n }\n </div>\n }\n @if (options.min) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MIN_AMOUNT | trans) }}\n <span [innerHTML]=\"options.min | trm_currency: options.currency\"></span>\n </div>\n }\n @if (options.max) {\n <div @insertRemove>\n {{ (I18N_KEY.CONSTRUCTOR_LABEL_MAX_AMOUNT | trans) }}\n <span [innerHTML]=\"options.max | trm_currency: options.currency\"></span>\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"] }]
5505
5483
  }], propDecorators: { loading: [{
5506
5484
  type: Input
5507
5485
  }], options: [{
@@ -5558,7 +5536,7 @@ class ConstructorFieldDateComponent {
5558
5536
  useExisting: forwardRef(() => ConstructorFieldDateComponent),
5559
5537
  multi: true
5560
5538
  }
5561
- ], ngImport: i0, template: "@if (control) {\r\n <app-constructor-field-text\r\n class=\"c-date__input\"\r\n [tabIndex]=\"tabIndex\"\r\n [config]=\"config\"\r\n [formControl]=\"control\"\r\n [matDatepicker]=\"picker\">\r\n <mat-datepicker-toggle [for]=\"picker\"\r\n app-c-text-suffix\r\n class=\"date__toggle\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <div class=\"date__toggleIcon\"\r\n matDatepickerToggleIcon\r\n app-c-text-suffix></div>\r\n </mat-datepicker-toggle>\r\n </app-constructor-field-text>\r\n\r\n <mat-datepicker #picker [tabIndex]=\"tabIndex\" [startAt]=\"startCalendarDate\"></mat-datepicker>\r\n}\r\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 }); }
5539
+ ], 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 }); }
5562
5540
  }
5563
5541
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFieldDateComponent, decorators: [{
5564
5542
  type: Component,
@@ -5568,7 +5546,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
5568
5546
  useExisting: forwardRef(() => ConstructorFieldDateComponent),
5569
5547
  multi: true
5570
5548
  }
5571
- ], standalone: true, imports: [ConstructorFieldTextComponent, FormsModule, ReactiveFormsModule, MatDatepickerToggle, MatDatepickerToggleIcon, MatDatepicker], template: "@if (control) {\r\n <app-constructor-field-text\r\n class=\"c-date__input\"\r\n [tabIndex]=\"tabIndex\"\r\n [config]=\"config\"\r\n [formControl]=\"control\"\r\n [matDatepicker]=\"picker\">\r\n <mat-datepicker-toggle [for]=\"picker\"\r\n app-c-text-suffix\r\n class=\"date__toggle\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <div class=\"date__toggleIcon\"\r\n matDatepickerToggleIcon\r\n app-c-text-suffix></div>\r\n </mat-datepicker-toggle>\r\n </app-constructor-field-text>\r\n\r\n <mat-datepicker #picker [tabIndex]=\"tabIndex\" [startAt]=\"startCalendarDate\"></mat-datepicker>\r\n}\r\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"] }]
5549
+ ], standalone: true, 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"] }]
5572
5550
  }], propDecorators: { config: [{
5573
5551
  type: Input
5574
5552
  }], tabIndex: [{
@@ -5581,11 +5559,11 @@ class ConstructorPreparationComponent {
5581
5559
  this.I18N_KEY = I18N_KEY;
5582
5560
  }
5583
5561
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorPreparationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5584
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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\">\r\n <h5> {{ I18N_KEY.CONSTRUCTOR_PREPARATION_HEADER | trans }} </h5>\r\n <div class=\"confirmation__content\">\r\n <ul class=\"confirmation__list\">\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}} </div>\r\n <div class=\"confirmation__value\"> {{methodName | trans}} </div>\r\n </li>\r\n\r\n @if (maskedWallet || wallet) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_WALLET | trans}} </div>\r\n <div class=\"confirmation__value\"> {{ maskedWallet || wallet}} </div>\r\n </li>\r\n }\r\n\r\n @if (amount) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT | trans}} </div>\r\n <div class=\"confirmation__value\" [innerHtml]=\"amount | trm_currency: currency\"> </div>\r\n </li>\r\n }\r\n\r\n @if (total) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT_FEE | trans}} </div>\r\n <div class=\"confirmation__value\" [innerHtml]=\"total | trm_currency: currency\"> </div>\r\n </li>\r\n }\r\n </ul>\r\n @if (confirmationText) {\r\n <p\r\n class=\"confirmation__text\" [innerHTML]=\"confirmationText | trans | sanitizeHtml\"></p>\r\n }\r\n <ng-content selector=\"[app-constructor-preparation-error]\"></ng-content>\r\n </div>\r\n</div>\r\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: TrmCurrencyPipe, name: "trm_currency" }, { kind: "pipe", type: HtmlSanitizerPipe, name: "sanitizeHtml" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
5562
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", 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\" [innerHtml]=\"amount | trm_currency: currency\"> </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\" [innerHtml]=\"total | trm_currency: currency\"> </div>\n </li>\n }\n </ul>\n @if (confirmationText) {\n <p\n class=\"confirmation__text\" [innerHTML]=\"confirmationText | trans | sanitizeHtml\"></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: TrmCurrencyPipe, name: "trm_currency" }, { kind: "pipe", type: HtmlSanitizerPipe, name: "sanitizeHtml" }, { kind: "pipe", type: TranslateByKeyPipe, name: "trans" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
5585
5563
  }
5586
5564
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorPreparationComponent, decorators: [{
5587
5565
  type: Component,
5588
- args: [{ selector: 'app-constructor-preparation', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, providers: [CurrencyPipe], imports: [TrmCurrencyPipe, HtmlSanitizerPipe, TranslateByKeyPipe], template: "<div class=\"confirmation\">\r\n <h5> {{ I18N_KEY.CONSTRUCTOR_PREPARATION_HEADER | trans }} </h5>\r\n <div class=\"confirmation__content\">\r\n <ul class=\"confirmation__list\">\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_PS | trans}} </div>\r\n <div class=\"confirmation__value\"> {{methodName | trans}} </div>\r\n </li>\r\n\r\n @if (maskedWallet || wallet) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_WALLET | trans}} </div>\r\n <div class=\"confirmation__value\"> {{ maskedWallet || wallet}} </div>\r\n </li>\r\n }\r\n\r\n @if (amount) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT | trans}} </div>\r\n <div class=\"confirmation__value\" [innerHtml]=\"amount | trm_currency: currency\"> </div>\r\n </li>\r\n }\r\n\r\n @if (total) {\r\n <li class=\"confirmation__list__item\">\r\n <div class=\"confirmation__header\"> {{I18N_KEY.CONSTRUCTOR_LABEL_AMOUNT_FEE | trans}} </div>\r\n <div class=\"confirmation__value\" [innerHtml]=\"total | trm_currency: currency\"> </div>\r\n </li>\r\n }\r\n </ul>\r\n @if (confirmationText) {\r\n <p\r\n class=\"confirmation__text\" [innerHTML]=\"confirmationText | trans | sanitizeHtml\"></p>\r\n }\r\n <ng-content selector=\"[app-constructor-preparation-error]\"></ng-content>\r\n </div>\r\n</div>\r\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"] }]
5566
+ args: [{ selector: 'app-constructor-preparation', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, providers: [CurrencyPipe], imports: [TrmCurrencyPipe, HtmlSanitizerPipe, TranslateByKeyPipe], 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\" [innerHtml]=\"amount | trm_currency: currency\"> </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\" [innerHtml]=\"total | trm_currency: currency\"> </div>\n </li>\n }\n </ul>\n @if (confirmationText) {\n <p\n class=\"confirmation__text\" [innerHTML]=\"confirmationText | trans | sanitizeHtml\"></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"] }]
5589
5567
  }], propDecorators: { maskedWallet: [{
5590
5568
  type: Input
5591
5569
  }], wallet: [{
@@ -5895,14 +5873,14 @@ class ConstructorFormComponent {
5895
5873
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: ConstructorFormComponent, isStandalone: true, selector: "app-constructor-form", inputs: { step: "step", error: "error", response: "response", feeLoading: "feeLoading", feeOptions: "feeOptions", currency: "currency", userCurrency: "userCurrency", loading: "loading", types: "types", canReturnToProject: "canReturnToProject", tabIndex: "tabIndex" }, outputs: { amountChanged: "amountChanged", back: "back", prepare: "prepare", confirm: "confirm", onPaymentChanged: "onPaymentChanged" }, providers: [
5896
5874
  ConstructorFormService,
5897
5875
  CountryTranslatePipe, CountriesSortPipe
5898
- ], viewQueries: [{ propertyName: "requisites", first: true, predicate: ["paymentRequisites"], descendants: true }, { propertyName: "hintMethod", first: true, predicate: ["hintMethod"], descendants: true }, { propertyName: "sdkList", predicate: CardSdkService, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [hidden]=\"\r\n form.payment.get(field.name)?.hasError('cde_error')\r\n \"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$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 }); }
5876
+ ], 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 <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 </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 @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:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"], dependencies: [{ kind: "pipe", type: CountryTranslatePipe, name: "country_translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1$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 }); }
5899
5877
  }
5900
5878
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ConstructorFormComponent, decorators: [{
5901
5879
  type: Component,
5902
5880
  args: [{ selector: 'app-constructor-form', changeDetection: ChangeDetectionStrategy.OnPush, animations: [insertRemoveTrigger], providers: [
5903
5881
  ConstructorFormService,
5904
5882
  CountryTranslatePipe, CountriesSortPipe
5905
- ], standalone: true, imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\r\n [formGroup]=\"form\"\r\n (ngSubmit)=\"submit()\"\r\n >\r\n @if (loading !== null) {\r\n @if (step === TERMINAL_STEP.Prepare) {\r\n <div class=\"constructor__fields\">\r\n @if (countrySearchString || countriesList.length > 1) {\r\n <div class=\"constructor__field\">\r\n <app-trm-select [data]=\"countriesList\"\r\n @insertRemove\r\n name=\"country\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_COUNTRY | trans\"\r\n formControlName=\"country\"\r\n class=\"c-field-select trm-form-field\"\r\n (search)=\"searchCountry($event)\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"fi\"\r\n [ngClass]=\"'fi-' + item.toLowerCase()\"></span>\r\n <span class=\"method__name\">{{item | country_translate: lang}}</span>\r\n </ng-template>\r\n </app-trm-select>\r\n </div>\r\n }\r\n @if (form.country.value) {\r\n <app-ps-select [methods]=\"methodsList\"\r\n @insertRemove\r\n formControlName=\"method\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n @if (form.config?.description) {\r\n <div class=\"constructor__hint text--warn\"\r\n app-ps-select-hint\r\n #hintMethod\r\n @insertRemove\r\n >\r\n {{description | trans }}\r\n </div>\r\n }\r\n </app-ps-select>\r\n\r\n @if (\r\n form.method?.hasError('required') &&\r\n form.method.touched &&\r\n form.method.dirty\r\n ) {\r\n <div class=\"gm-error\" @insertRemove>\r\n {{ I18N_KEY.VALIDATION_REQUIRED | trans }}\r\n </div>\r\n }\r\n }\r\n\r\n @if (form.ready) {\r\n <div formGroupName=\"payment\"\r\n @insertRemove\r\n #paymentRequisites\r\n class=\"constructor__fields constructor__fields--reverse\">\r\n @if (form.method.value && form.amountDynamic) {\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {label: I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans, tabIndex: 0}\"></ng-container>\r\n }\r\n @for (field of form.fields; track field.name; let i = $index) {\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Iframe) {\r\n @if (form.payment.get(field.name)?.hasError('cde_error')) {\r\n <div class=\"constructor__hint cde-error\" @insertRemove>\r\n {{\r\n form.payment.get(field.name).getError('cde_error')\r\n | trans\r\n }}\r\n </div>\r\n }\r\n <app-constructor-field-iframe\r\n [formControlName]=\"field.name\"\r\n @insertRemove\r\n [hidden]=\"\r\n form.payment.get(field.name)?.hasError('cde_error')\r\n \"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n </app-constructor-field-iframe>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Select) {\r\n <app-constructor-field-select\r\n @insertRemove\r\n [config]=\"field\"\r\n [items]=\"field?.options?.items\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n ></app-constructor-field-select>\r\n }\r\n @if ([CONSTRUCTOR_FIELD_TYPES.Text, CONSTRUCTOR_FIELD_TYPES.Number, CONSTRUCTOR_FIELD_TYPES.Email].includes(field.type)) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n (maskedValueChange)=\"changeTextFieldValue($event, field)\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-text>\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Amount) {\r\n <app-constructor-field-text\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\">\r\n <app-method-amount-hint app-c-text-hint\r\n class=\"constructor__hint\"\r\n [loading]=\"feeLoading\"\r\n [options]=\"feeOptions || field.options\"\r\n ></app-method-amount-hint>\r\n <div app-c-text-suffix\r\n class=\"constructor__currency\"\r\n [class.constructor__currency--transparent]=\"form.isAmountEditable\"\r\n >\r\n <ng-container *ngTemplateOutlet=\"currencyTpl; context: {tabIndex: form.fields.length - i + tabIndex}\"></ng-container>\r\n </div>\r\n </app-constructor-field-text>\r\n @if (hasCurrencyMethodSelector) {\r\n <app-trm-select\r\n @insertRemove\r\n class=\"constructor-field\"\r\n [label]=\"I18N_KEY.CONSTRUCTOR_LABEL_CURRENCY | trans\"\r\n [formControl]=\"form.currency\"\r\n [searchable]=\"false\"\r\n [data]=\"currenciesList\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\" [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n }\r\n }\r\n @if (field.type === CONSTRUCTOR_FIELD_TYPES.Date) {\r\n <app-constructor-field-date\r\n @insertRemove\r\n [config]=\"field\"\r\n [formControlName]=\"field.name\"\r\n [tabIndex]=\"form.fields.length - i + tabIndex\"></app-constructor-field-date>\r\n }\r\n }\r\n <ng-template #currencyTpl let-label=\"label\" let-tabIndex=\"tabIndex\">\r\n <app-trm-select\r\n @insertRemove\r\n [label]=\"label\"\r\n [formControl]=\"form.userCurrency\"\r\n [searchable]=\"false\"\r\n [data]=\"userCurrenciesList\"\r\n [tabIndex]=\"tabIndex\"\r\n >\r\n <ng-template trmSelectLabelTemplate let-item=\"item\">\r\n <span class=\"trm-icon\"\r\n [ngClass]=\"'trm-curr-' + item.toLowerCase()\"\r\n [title]=\"item\"></span>\r\n {{item}}\r\n </ng-template>\r\n </app-trm-select>\r\n </ng-template>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-fields\">\r\n @for (i of skeletonLength; track $index) {\r\n <div class=\"trm-skeleton-field\">\r\n <gm-skeleton [count]=\"1\" [shape]=\"'rect-md'\" [size]=\"18\"></gm-skeleton>\r\n <gm-skeleton [count]=\"1\" [size]=\"50\"></gm-skeleton>\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (error && !form.methodInfoLoading) {\r\n <div class=\"trm-error\"\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </div>\r\n }\r\n @if (step === TERMINAL_STEP.Confirmation) {\r\n <app-constructor-preparation\r\n @insertRemove\r\n [currency]=\"response?.currency\"\r\n [methodName]=\"form.getTypeNameById(response.typeId)\"\r\n [wallet]=\"response.wallet\"\r\n [maskedWallet]=\"maskedWallet\"\r\n [amount]=\"response.amount\"\r\n [total]=\"response.total\"\r\n [confirmationText]=\"form.config?.confirmation\"\r\n >\r\n @if (error && !form.payment.pending) {\r\n <div class=\"trm-error\"\r\n app-constructor-preparation-error\r\n @insertRemove\r\n >\r\n {{ error | trans }}\r\n </div>\r\n }\r\n </app-constructor-preparation>\r\n }\r\n <div class=\"constructor__actions\"\r\n @insertRemove>\r\n <button class=\"trm-button trm-button--primary constructor__actions-continue\"\r\n type=\"submit\"\r\n [tabindex]=\"form.fields.length + tabIndex\">\r\n {{I18N_KEY.CONSTRUCTOR_LABEL_CONTINUE | trans}}\r\n @if (loading) {\r\n <span class=\"trm-spinner trm-spinner-white\"></span>\r\n }\r\n </button>\r\n <button class=\"trm-button trm-button--secondary constructor__actions-back\"\r\n type=\"button\"\r\n [tabindex]=\"form.fields.length + tabIndex\"\r\n (click)=\"back.emit()\"> {{ backBtnLabel | trans}}</button>\r\n </div>\r\n } @else {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"4\" [gap]=\"20\" [size]=\"80\"></gm-skeleton>\r\n <gm-skeleton [count]=\"2\" [gap]=\"10\" [size]=\"48\"></gm-skeleton>\r\n </div>\r\n }\r\n</form>\r\n", styles: [":host{display:block}.constructor{display:flex;flex-direction:column;gap:32px;justify-content:flex-start;align-items:stretch}.constructor__fields{display:flex;flex-direction:column;gap:20px;justify-content:flex-start;align-items:stretch}.constructor__fields--reverse{flex-direction:column-reverse}.constructor__fields .fi{border-radius:2px;overflow:hidden;border:1px solid rgba(0,0,0,.08);box-sizing:border-box;background-origin:border-box;flex-shrink:0;height:15px}.constructor__fields .fi-other{border-color:transparent}.constructor__currency{--trm-select-border-radius: 0 10px 10px 0;display:flex;align-items:center;position:absolute;bottom:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
5883
+ ], standalone: true, imports: [CountryTranslatePipe, CountriesSortPipe, FormsModule, ReactiveFormsModule, TrmSelectComponent, TrmSelectLabelTemplateDirective, NgClass, PsSelectComponent, NgTemplateOutlet, ConstructorFieldIframeComponent, ConstructorFieldSelectComponent, ConstructorFieldTextComponent, MethodAmountHintComponent, ConstructorFieldDateComponent, ConstructorPreparationComponent, TabIndexFocusDirective, CountryTranslatePipe, TranslateByKeyPipe, GmSkeletonComponent], template: "<form class=\"constructor\"\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 <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 </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 @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:0;right:0;flex-shrink:0;min-height:46px}@media (min-width: 768px){.constructor__currency{min-height:50px}}.constructor__currency .trm-divider{margin:5px 0;align-self:stretch}.constructor__currency--transparent{--trm-select-bg-color: transparent;--trm-select-bg-color--disabled: transparent;--trm-select-border-color: transparent;--trm-select-border-color--hover: transparent;--trm-select-border-color--focus: transparent}.constructor__actions{display:flex;flex-direction:column;gap:10px;justify-content:flex-start;align-items:flex-start}.constructor__hint{font-weight:400;font-size:14px;line-height:22px;color:var(--color-base-350);margin-top:8px}.constructor__hint.cde-error{font-weight:500;font-size:14px;line-height:20px;color:var(--color-red-500)}.constructor .constructor__actions-continue{position:relative}.constructor .constructor__actions-continue .trm-spinner{position:absolute;right:15px}\n"] }]
5906
5884
  }], propDecorators: { step: [{
5907
5885
  type: Input
5908
5886
  }], error: [{
@@ -5966,6 +5944,7 @@ class TerminalLayoutComponent {
5966
5944
  this.TERMINAL_STEP = TerminalStep;
5967
5945
  this.types = [];
5968
5946
  this.step = TerminalStep.Prepare;
5947
+ this.sessionLoading = null;
5969
5948
  this._submitted = false;
5970
5949
  this.feeCalculateSubject = new Subject();
5971
5950
  this.feeLoading = false;
@@ -6009,8 +5988,10 @@ class TerminalLayoutComponent {
6009
5988
  this.currency = sessionInfo.defaultCurrency;
6010
5989
  this.projectName = sessionInfo.projectName;
6011
5990
  this.description = sessionInfo.description;
5991
+ this.sessionLoading = false;
6012
5992
  this.cd.markForCheck();
6013
5993
  }, () => {
5994
+ this.sessionLoading = false;
6014
5995
  this.catchError();
6015
5996
  });
6016
5997
  this.pushState();
@@ -6026,6 +6007,7 @@ class TerminalLayoutComponent {
6026
6007
  return;
6027
6008
  }
6028
6009
  this._submitted = true;
6010
+ this.sessionLoading = true;
6029
6011
  this.sessionDS
6030
6012
  .prepare(data)
6031
6013
  .subscribe((resp) => {
@@ -6037,9 +6019,11 @@ class TerminalLayoutComponent {
6037
6019
  this.data = resp;
6038
6020
  this.data.typeId = data.typeId;
6039
6021
  this._submitted = false;
6022
+ this.sessionLoading = false;
6040
6023
  this.cd.markForCheck();
6041
6024
  }, () => {
6042
6025
  this._submitted = false;
6026
+ this.sessionLoading = false;
6043
6027
  this.catchError();
6044
6028
  });
6045
6029
  }
@@ -6048,6 +6032,7 @@ class TerminalLayoutComponent {
6048
6032
  return;
6049
6033
  }
6050
6034
  this._submitted = true;
6035
+ this.sessionLoading = true;
6051
6036
  this.sessionDS
6052
6037
  .confirm()
6053
6038
  .subscribe((resp) => {
@@ -6063,9 +6048,11 @@ class TerminalLayoutComponent {
6063
6048
  this._statusText = resp.message;
6064
6049
  }
6065
6050
  this._submitted = false;
6051
+ this.sessionLoading = false;
6066
6052
  this.cd.markForCheck();
6067
6053
  }, () => {
6068
6054
  this._submitted = false;
6055
+ this.sessionLoading = false;
6069
6056
  this.catchError();
6070
6057
  });
6071
6058
  }
@@ -6083,8 +6070,12 @@ class TerminalLayoutComponent {
6083
6070
  this.location.back();
6084
6071
  }
6085
6072
  else {
6073
+ this.sessionLoading = true;
6086
6074
  this.sessionDS.close()
6087
- .pipe(finalize(() => this.cd.markForCheck()))
6075
+ .pipe(finalize(() => {
6076
+ this.sessionLoading = false;
6077
+ this.cd.markForCheck();
6078
+ }))
6088
6079
  .subscribe();
6089
6080
  }
6090
6081
  }
@@ -6142,7 +6133,7 @@ class TerminalLayoutComponent {
6142
6133
  static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.2", type: TerminalLayoutComponent, isStandalone: true, selector: "app-terminal-layout", providers: [
6143
6134
  SessionDataSource,
6144
6135
  CurrencyPipe
6145
- ], viewQueries: [{ propertyName: "scrollComponent", first: true, predicate: ["scrollComponent"], descendants: true }], ngImport: i0, template: "<ng-scrollbar appearance=\"compact\">\r\n <div class=\"terminal-layout\">\r\n <section class=\"terminal\">\r\n <div class=\"terminal__content\">\r\n <header class=\"terminal__header\">\r\n <i class=\"terminal__header-logo\"\r\n [class]=\"logoClass\"></i>\r\n <div class=\"terminal__header-lang\">\r\n @if (hasChoice) {\r\n <app-terminal-lang-switcher (langChange)=\"changeLang()\"\r\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\r\n }\r\n </div>\r\n </header>\r\n <div class=\"terminal__form\">\r\n @if (sessionDS.loading$ | async) {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\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 } @else {\r\n @if (projectName) {\r\n <div class=\"terminal__info\">\r\n <h5 class=\"terminal__info__name\"> {{ projectName }} </h5>\r\n @if (description) {\r\n <p class=\"terminal__info__desc\"> {{ description }} </p>\r\n }\r\n </div>\r\n }\r\n @if (step !== TERMINAL_STEP.Status && !hasStatusError) {\r\n <app-constructor-form\r\n [feeLoading]=\"feeLoading\"\r\n [feeOptions]=\"feeOptions\"\r\n [loading]=\"sessionDS.loadingConfirm$ | async\"\r\n [step]=\"step\"\r\n [types]=\"types\"\r\n [currency]=\"currency\"\r\n [response]=\"data\"\r\n [error]=\"statusText\"\r\n (prepare)=\"prepare($event)\"\r\n (onPaymentChanged)=\"checkFatalError(); calculateFee($event)\"\r\n (back)=\"back()\"\r\n [canReturnToProject]=\"sessionDS.canReturnToProject\"\r\n (confirm)=\"confirm()\"\r\n [tabIndex]=\"2\"></app-constructor-form>\r\n } @else {\r\n <app-constructor-status class=\"terminal__status\"\r\n [failed]=\"hasStatusError\"\r\n [message]=\"statusText ? (statusText | trans) : ''\"\r\n [backUrl]=\"returnBackUrl\"\r\n ></app-constructor-status>\r\n }\r\n }\r\n\r\n </div>\r\n </div>\r\n </section>\r\n <footer class=\"terminal-footer\">\r\n <i class=\"terminal-footer__logo\"></i>\r\n <p class=\"terminal-footer__txt\">\r\n {{ footerText }}\r\n </p>\r\n </footer>\r\n </div>\r\n</ng-scrollbar>\r\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"] }] }); }
6136
+ ], 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"] }] }); }
6146
6137
  }
6147
6138
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: TerminalLayoutComponent, decorators: [{
6148
6139
  type: Component,
@@ -6155,7 +6146,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
6155
6146
  ConstructorFormComponent, ConstructorStatusComponent,
6156
6147
  AsyncPipe,
6157
6148
  TranslateByKeyPipe, GmSkeletonComponent
6158
- ], template: "<ng-scrollbar appearance=\"compact\">\r\n <div class=\"terminal-layout\">\r\n <section class=\"terminal\">\r\n <div class=\"terminal__content\">\r\n <header class=\"terminal__header\">\r\n <i class=\"terminal__header-logo\"\r\n [class]=\"logoClass\"></i>\r\n <div class=\"terminal__header-lang\">\r\n @if (hasChoice) {\r\n <app-terminal-lang-switcher (langChange)=\"changeLang()\"\r\n [tabIndex]=\"1\"></app-terminal-lang-switcher>\r\n }\r\n </div>\r\n </header>\r\n <div class=\"terminal__form\">\r\n @if (sessionDS.loading$ | async) {\r\n <div class=\"trm-skeleton-group\">\r\n <gm-skeleton [count]=\"1\" [size]=\"120\"></gm-skeleton>\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 } @else {\r\n @if (projectName) {\r\n <div class=\"terminal__info\">\r\n <h5 class=\"terminal__info__name\"> {{ projectName }} </h5>\r\n @if (description) {\r\n <p class=\"terminal__info__desc\"> {{ description }} </p>\r\n }\r\n </div>\r\n }\r\n @if (step !== TERMINAL_STEP.Status && !hasStatusError) {\r\n <app-constructor-form\r\n [feeLoading]=\"feeLoading\"\r\n [feeOptions]=\"feeOptions\"\r\n [loading]=\"sessionDS.loadingConfirm$ | async\"\r\n [step]=\"step\"\r\n [types]=\"types\"\r\n [currency]=\"currency\"\r\n [response]=\"data\"\r\n [error]=\"statusText\"\r\n (prepare)=\"prepare($event)\"\r\n (onPaymentChanged)=\"checkFatalError(); calculateFee($event)\"\r\n (back)=\"back()\"\r\n [canReturnToProject]=\"sessionDS.canReturnToProject\"\r\n (confirm)=\"confirm()\"\r\n [tabIndex]=\"2\"></app-constructor-form>\r\n } @else {\r\n <app-constructor-status class=\"terminal__status\"\r\n [failed]=\"hasStatusError\"\r\n [message]=\"statusText ? (statusText | trans) : ''\"\r\n [backUrl]=\"returnBackUrl\"\r\n ></app-constructor-status>\r\n }\r\n }\r\n\r\n </div>\r\n </div>\r\n </section>\r\n <footer class=\"terminal-footer\">\r\n <i class=\"terminal-footer__logo\"></i>\r\n <p class=\"terminal-footer__txt\">\r\n {{ footerText }}\r\n </p>\r\n </footer>\r\n </div>\r\n</ng-scrollbar>\r\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"] }]
6149
+ ], 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"] }]
6159
6150
  }], ctorParameters: () => [], propDecorators: { scrollComponent: [{
6160
6151
  type: ViewChild,
6161
6152
  args: ['scrollComponent']
@@ -6171,7 +6162,7 @@ class ErrorComponent {
6171
6162
  this.I18N_KEY = I18N_KEY;
6172
6163
  }
6173
6164
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ErrorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
6174
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.2", type: ErrorComponent, isStandalone: true, selector: "app-error", ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"false\">\r\n <app-constructor-status terminal-layout-status\r\n [failed]=\"true\"\r\n [failTitle]=\"(I18N_KEY.ERROR_OCCUR | trans)\"\r\n [hasSupportHint]=\"false\"\r\n >\r\n </app-constructor-status>\r\n</app-terminal-layout-tpl>\r\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" }] }); }
6165
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.2", 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" }] }); }
6175
6166
  }
6176
6167
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: ErrorComponent, decorators: [{
6177
6168
  type: Component,
@@ -6179,7 +6170,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
6179
6170
  TerminalLayoutTplComponent,
6180
6171
  ConstructorStatusComponent,
6181
6172
  TranslateByKeyPipe,
6182
- ], template: "<app-terminal-layout-tpl [loading]=\"false\">\r\n <app-constructor-status terminal-layout-status\r\n [failed]=\"true\"\r\n [failTitle]=\"(I18N_KEY.ERROR_OCCUR | trans)\"\r\n [hasSupportHint]=\"false\"\r\n >\r\n </app-constructor-status>\r\n</app-terminal-layout-tpl>\r\n" }]
6173
+ ], 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" }]
6183
6174
  }] });
6184
6175
 
6185
6176
  var error_component = /*#__PURE__*/Object.freeze({
@@ -6533,7 +6524,7 @@ class CheckinPageComponent {
6533
6524
  useFactory: (activatedRoute) => activatedRoute.snapshot.paramMap.get('mode')
6534
6525
  },
6535
6526
  CheckinDatasource
6536
- ], ngImport: i0, template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\r\n @if (!(loading | async)) {\r\n <app-constructor-status terminal-layout-status\r\n [inProgress]=\"inProgress\"\r\n [failed]=\"hasStatusError\"\r\n [animation]=\"animation\"\r\n [progressTitle]=\"(I18N_KEY.PROGRESS_TITLE | trans)\"\r\n [failTitle]=\"(I18N_KEY.FAIL_TITLE | trans)\"\r\n [successTitle]=\"(I18N_KEY.SUCCESS_TITLE | trans)\"\r\n [hasSupportHint]=\"false\"\r\n [message]=\"(message | trans) + operationIdHint\"\r\n [backUrl]=\"returnBackUrl\"\r\n [backUrlTitle]=\"I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans\"\r\n >\r\n @if (redirectTimerStarted) {\r\n <div constructor-status-button-hint>\r\n {{ I18N_KEY.REDIRECT_TEXT | trans }}&nbsp;<b>{{redirectTime}}</b>\r\n </div>\r\n }\r\n </app-constructor-status>\r\n }\r\n</app-terminal-layout-tpl>\r\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" }] }); }
6527
+ ], 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 }}&nbsp;<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" }] }); }
6537
6528
  }
6538
6529
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CheckinPageComponent, decorators: [{
6539
6530
  type: Component,
@@ -6544,7 +6535,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImpor
6544
6535
  useFactory: (activatedRoute) => activatedRoute.snapshot.paramMap.get('mode')
6545
6536
  },
6546
6537
  CheckinDatasource
6547
- ], standalone: true, imports: [TerminalLayoutTplComponent, ConstructorStatusComponent, AsyncPipe, TranslateByKeyPipe], template: "<app-terminal-layout-tpl [loading]=\"loading | async\">\r\n @if (!(loading | async)) {\r\n <app-constructor-status terminal-layout-status\r\n [inProgress]=\"inProgress\"\r\n [failed]=\"hasStatusError\"\r\n [animation]=\"animation\"\r\n [progressTitle]=\"(I18N_KEY.PROGRESS_TITLE | trans)\"\r\n [failTitle]=\"(I18N_KEY.FAIL_TITLE | trans)\"\r\n [successTitle]=\"(I18N_KEY.SUCCESS_TITLE | trans)\"\r\n [hasSupportHint]=\"false\"\r\n [message]=\"(message | trans) + operationIdHint\"\r\n [backUrl]=\"returnBackUrl\"\r\n [backUrlTitle]=\"I18N_KEY.CONSTRUCTOR_LABEL_RETURN_TO_SHOP | trans\"\r\n >\r\n @if (redirectTimerStarted) {\r\n <div constructor-status-button-hint>\r\n {{ I18N_KEY.REDIRECT_TEXT | trans }}&nbsp;<b>{{redirectTime}}</b>\r\n </div>\r\n }\r\n </app-constructor-status>\r\n }\r\n</app-terminal-layout-tpl>\r\n" }]
6538
+ ], standalone: true, 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 }}&nbsp;<b>{{redirectTime}}</b>\n </div>\n }\n </app-constructor-status>\n }\n</app-terminal-layout-tpl>\n" }]
6548
6539
  }], ctorParameters: () => [] });
6549
6540
 
6550
6541
  var checkinPage_component = /*#__PURE__*/Object.freeze({