@foxy.io/elements 1.15.0-beta.1 → 1.15.0-beta.10

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 (343) hide show
  1. package/dist/cdn/foxy-access-recovery-form.js +1 -1
  2. package/dist/cdn/foxy-address-card.js +2 -2
  3. package/dist/cdn/foxy-address-form.js +1 -1
  4. package/dist/cdn/foxy-applied-tax-card.js +1 -1
  5. package/dist/cdn/foxy-attribute-card.js +1 -1
  6. package/dist/cdn/foxy-attribute-form.js +1 -1
  7. package/dist/cdn/foxy-cancellation-form.js +1 -1
  8. package/dist/cdn/foxy-collection-page.js +1 -1
  9. package/dist/cdn/foxy-collection-pages.js +1 -1
  10. package/dist/cdn/foxy-coupon-card.js +1 -0
  11. package/dist/cdn/foxy-coupon-code-form.js +1 -0
  12. package/dist/cdn/foxy-coupon-codes-form.js +1 -0
  13. package/dist/cdn/foxy-coupon-form.js +1 -0
  14. package/dist/cdn/foxy-custom-field-card.js +1 -1
  15. package/dist/cdn/foxy-custom-field-form.js +1 -1
  16. package/dist/cdn/foxy-customer-api.js +1 -1
  17. package/dist/cdn/foxy-customer-card.js +1 -1
  18. package/dist/cdn/foxy-customer-form.js +1 -1
  19. package/dist/cdn/foxy-customer-portal-settings.js +1 -972
  20. package/dist/cdn/foxy-customer-portal.js +13 -13
  21. package/dist/cdn/foxy-customer.js +2 -2
  22. package/dist/cdn/foxy-customers-table.js +1 -1
  23. package/dist/cdn/foxy-discount-card.js +1 -1
  24. package/dist/cdn/foxy-donation.js +1 -1
  25. package/dist/cdn/foxy-email-template-form.js +1 -1
  26. package/dist/cdn/foxy-error-entry-card.js +1 -1
  27. package/dist/cdn/foxy-form-dialog.js +1 -1
  28. package/dist/cdn/foxy-generate-codes-form.js +1 -0
  29. package/dist/cdn/foxy-gift-card-card.js +1 -0
  30. package/dist/cdn/foxy-gift-card-code-form.js +1 -0
  31. package/dist/cdn/foxy-gift-card-codes-form.js +1 -0
  32. package/dist/cdn/foxy-gift-card-form.js +1 -0
  33. package/dist/cdn/foxy-i18n.js +1 -1
  34. package/dist/cdn/foxy-items-form.js +1 -1
  35. package/dist/cdn/foxy-nucleon-element.js +1 -1
  36. package/dist/cdn/foxy-pagination.js +1 -0
  37. package/dist/cdn/foxy-payment-card.js +1 -1
  38. package/dist/cdn/foxy-payment-method-card.js +1 -1
  39. package/dist/cdn/foxy-query-builder.js +1 -69
  40. package/dist/cdn/foxy-sign-in-form.js +1 -1
  41. package/dist/cdn/foxy-spinner.js +2 -2
  42. package/dist/cdn/foxy-subscription-card.js +1 -1
  43. package/dist/cdn/foxy-subscription-form.js +4 -4
  44. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  45. package/dist/cdn/foxy-table.js +1 -1
  46. package/dist/cdn/foxy-tax-card.js +1 -1
  47. package/dist/cdn/foxy-tax-form.js +1 -1
  48. package/dist/cdn/foxy-template-config-form.js +1 -1
  49. package/dist/cdn/foxy-template-form.js +1 -1
  50. package/dist/cdn/foxy-transaction-card.js +1 -1
  51. package/dist/cdn/foxy-transactions-table.js +1 -1
  52. package/dist/cdn/foxy-user-form.js +1 -1
  53. package/dist/cdn/foxy-users-table.js +1 -1
  54. package/dist/cdn/shared-00d6a968.js +1 -0
  55. package/dist/cdn/shared-023a97c2.js +302 -0
  56. package/dist/cdn/{shared-91e768be.js → shared-027c537d.js} +1 -1
  57. package/dist/cdn/{shared-f0a83bd6.js → shared-073cb8e9.js} +1 -1
  58. package/dist/cdn/{shared-8a7bee0d.js → shared-09c5f9f1.js} +1 -1
  59. package/dist/cdn/{shared-94b0ae99.js → shared-0f38a631.js} +2 -2
  60. package/dist/cdn/{shared-200f613b.js → shared-1a67bc75.js} +2 -2
  61. package/dist/cdn/{shared-34b2c1e2.js → shared-21419f10.js} +1 -1
  62. package/dist/cdn/{shared-b5147166.js → shared-340f7584.js} +3 -3
  63. package/dist/cdn/{shared-44cfc617.js → shared-39e3ae67.js} +1 -1
  64. package/dist/cdn/shared-3f0a9c2c.js +1 -0
  65. package/dist/cdn/shared-3f965dce.js +1 -0
  66. package/dist/cdn/{shared-e7f8ffe9.js → shared-448781f9.js} +1 -1
  67. package/dist/cdn/{shared-1761daef.js → shared-5535f38f.js} +1 -1
  68. package/dist/cdn/{shared-0ced76a0.js → shared-5a54a9bc.js} +1 -1
  69. package/dist/cdn/shared-5e2fd1c7.js +1 -0
  70. package/dist/cdn/{shared-5c8b531d.js → shared-60d43523.js} +1 -1
  71. package/dist/cdn/shared-625c1272.js +69 -0
  72. package/dist/cdn/shared-65dfd512.js +131 -0
  73. package/dist/cdn/{shared-a46edf4b.js → shared-756034e4.js} +1 -1
  74. package/dist/cdn/{shared-00563cb0.js → shared-7f0a9790.js} +1 -1
  75. package/dist/cdn/shared-84d2d490.js +1 -0
  76. package/dist/cdn/{shared-df573cea.js → shared-8b20bc23.js} +0 -0
  77. package/dist/cdn/shared-8c8a910c.js +1 -0
  78. package/dist/cdn/{shared-5f54e916.js → shared-9cd49a3e.js} +4 -4
  79. package/dist/cdn/{shared-7a42073a.js → shared-9fc4a896.js} +1 -1
  80. package/dist/cdn/{shared-bb824ab4.js → shared-a040d79d.js} +2 -2
  81. package/dist/cdn/{shared-bc2bfe52.js → shared-ab71552b.js} +1 -1
  82. package/dist/cdn/shared-ae8cd227.js +1 -0
  83. package/dist/cdn/{shared-322e60b1.js → shared-ba39823e.js} +1 -1
  84. package/dist/cdn/shared-d58c947c.js +804 -0
  85. package/dist/cdn/{shared-593f7e2c.js → shared-df730f90.js} +1 -1
  86. package/dist/cdn/shared-e55088b4.js +1 -0
  87. package/dist/cdn/shared-ecfd3539.js +1 -0
  88. package/dist/cdn/shared-f2a69797.js +1 -0
  89. package/dist/cdn/{shared-16f72e27.js → shared-f4ad24f4.js} +1 -1
  90. package/dist/cdn/{shared-ec861f31.js → shared-fab8c705.js} +3 -3
  91. package/dist/cdn/translations/access-recovery-form/en.json +12 -0
  92. package/dist/cdn/translations/address-card/en.json +11 -0
  93. package/dist/cdn/translations/address-form/en.json +27 -0
  94. package/dist/cdn/translations/applied-tax-card/en.json +9 -0
  95. package/dist/cdn/translations/attribute-card/en.json +7 -0
  96. package/dist/cdn/translations/attribute-form/en.json +22 -0
  97. package/dist/cdn/translations/cancellation-form/en.json +10 -0
  98. package/dist/cdn/translations/country/pl.json +251 -0
  99. package/dist/cdn/translations/coupon-card/en.json +36 -0
  100. package/dist/cdn/translations/coupon-code-form/en.json +17 -0
  101. package/dist/cdn/translations/coupon-codes-form/en.json +20 -0
  102. package/dist/cdn/translations/coupon-form/en.json +186 -0
  103. package/dist/cdn/translations/custom-field-card/en.json +7 -0
  104. package/dist/cdn/translations/custom-field-form/en.json +19 -0
  105. package/dist/cdn/translations/customer/en.json +247 -0
  106. package/dist/cdn/translations/customer-card/en.json +7 -0
  107. package/dist/cdn/translations/customer-form/en.json +21 -0
  108. package/dist/cdn/translations/customer-portal/de.json +202 -14
  109. package/dist/cdn/translations/customer-portal/en.json +202 -14
  110. package/dist/cdn/translations/customer-portal/es.json +202 -14
  111. package/dist/cdn/translations/customer-portal/pl.json +223 -0
  112. package/dist/cdn/translations/customer-portal/zh-hk.json +202 -14
  113. package/dist/cdn/translations/customers-table/en.json +9 -0
  114. package/dist/cdn/translations/discount-card/en.json +8 -0
  115. package/dist/cdn/translations/email-template-form/en.json +25 -0
  116. package/dist/cdn/translations/error-entry-card/en.json +7 -0
  117. package/dist/cdn/translations/generate-codes-form/en.json +19 -0
  118. package/dist/cdn/translations/gift-card-card/en.json +9 -0
  119. package/dist/cdn/translations/gift-card-code-form/en.json +19 -0
  120. package/dist/cdn/translations/gift-card-codes-form/en.json +25 -0
  121. package/dist/cdn/translations/gift-card-form/en.json +314 -0
  122. package/dist/cdn/translations/pagination/en.json +7 -0
  123. package/dist/cdn/translations/payment-card/en.json +12 -0
  124. package/dist/cdn/translations/payment-method-card/en.json +13 -0
  125. package/dist/cdn/translations/query-builder/en.json +32 -0
  126. package/dist/cdn/translations/sign-in-form/en.json +21 -0
  127. package/dist/cdn/translations/spinner/en.json +7 -0
  128. package/dist/cdn/translations/subscription-card/en.json +26 -0
  129. package/dist/cdn/translations/subscription-form/en.json +76 -0
  130. package/dist/cdn/translations/subscriptions-table/en.json +26 -0
  131. package/dist/cdn/translations/tax-card/en.json +11 -0
  132. package/dist/cdn/translations/tax-form/en.json +38 -0
  133. package/dist/cdn/translations/template-config-form/en.json +107 -0
  134. package/dist/cdn/translations/template-form/en.json +23 -0
  135. package/dist/cdn/translations/transaction-card/en.json +25 -0
  136. package/dist/cdn/translations/transactions-table/en.json +22 -0
  137. package/dist/cdn/translations/user-form/en.json +26 -0
  138. package/dist/cdn/translations/users-table/en.json +44 -0
  139. package/dist/elements/private/Checkbox/Checkbox.js +36 -22
  140. package/dist/elements/private/Checkbox/Checkbox.js.map +1 -1
  141. package/dist/elements/private/Choice/Choice.js +1 -0
  142. package/dist/elements/private/Choice/Choice.js.map +1 -1
  143. package/dist/elements/private/EditableList/EditableList.d.ts +20 -0
  144. package/dist/elements/private/EditableList/EditableList.js +124 -0
  145. package/dist/elements/private/EditableList/EditableList.js.map +1 -0
  146. package/dist/elements/private/FrequencyInput/FrequencyInput.d.ts +7 -6
  147. package/dist/elements/private/FrequencyInput/FrequencyInput.js +10 -23
  148. package/dist/elements/private/FrequencyInput/FrequencyInput.js.map +1 -1
  149. package/dist/elements/public/AccessRecoveryForm/AccessRecoveryForm.js +1 -1
  150. package/dist/elements/public/AccessRecoveryForm/AccessRecoveryForm.js.map +1 -1
  151. package/dist/elements/public/AttributeCard/types.d.ts +3 -3
  152. package/dist/elements/public/AttributeCard/types.js.map +1 -1
  153. package/dist/elements/public/AttributeForm/AttributeForm.js +2 -1
  154. package/dist/elements/public/AttributeForm/AttributeForm.js.map +1 -1
  155. package/dist/elements/public/AttributeForm/types.d.ts +3 -3
  156. package/dist/elements/public/AttributeForm/types.js.map +1 -1
  157. package/dist/elements/public/CollectionPage/CollectionPage.js +3 -1
  158. package/dist/elements/public/CollectionPage/CollectionPage.js.map +1 -1
  159. package/dist/elements/public/CollectionPage/types.d.ts +2 -0
  160. package/dist/elements/public/CollectionPage/types.js.map +1 -1
  161. package/dist/elements/public/CouponCard/CouponCard.d.ts +29 -0
  162. package/dist/elements/public/CouponCard/CouponCard.js +131 -0
  163. package/dist/elements/public/CouponCard/CouponCard.js.map +1 -0
  164. package/dist/elements/public/CouponCard/index.d.ts +5 -0
  165. package/dist/elements/public/CouponCard/index.js +7 -0
  166. package/dist/elements/public/CouponCard/index.js.map +1 -0
  167. package/dist/elements/public/CouponCard/types.d.ts +15 -0
  168. package/dist/elements/public/CouponCard/types.js +2 -0
  169. package/dist/elements/public/CouponCard/types.js.map +1 -0
  170. package/dist/elements/public/CouponCodeForm/CouponCodeForm.d.ts +45 -0
  171. package/dist/elements/public/CouponCodeForm/CouponCodeForm.js +218 -0
  172. package/dist/elements/public/CouponCodeForm/CouponCodeForm.js.map +1 -0
  173. package/dist/elements/public/CouponCodeForm/index.d.ts +8 -0
  174. package/dist/elements/public/CouponCodeForm/index.js +10 -0
  175. package/dist/elements/public/CouponCodeForm/index.js.map +1 -0
  176. package/dist/elements/public/CouponCodeForm/types.d.ts +15 -0
  177. package/dist/elements/public/CouponCodeForm/types.js +2 -0
  178. package/dist/elements/public/CouponCodeForm/types.js.map +1 -0
  179. package/dist/elements/public/CouponCodesForm/CouponCodesForm.d.ts +31 -0
  180. package/dist/elements/public/CouponCodesForm/CouponCodesForm.js +218 -0
  181. package/dist/elements/public/CouponCodesForm/CouponCodesForm.js.map +1 -0
  182. package/dist/elements/public/CouponCodesForm/index.d.ts +8 -0
  183. package/dist/elements/public/CouponCodesForm/index.js +12 -0
  184. package/dist/elements/public/CouponCodesForm/index.js.map +1 -0
  185. package/dist/elements/public/CouponCodesForm/internal/InternalCouponCodesFormListItem.d.ts +14 -0
  186. package/dist/elements/public/CouponCodesForm/internal/InternalCouponCodesFormListItem.js +48 -0
  187. package/dist/elements/public/CouponCodesForm/internal/InternalCouponCodesFormListItem.js.map +1 -0
  188. package/dist/elements/public/CouponCodesForm/types.d.ts +17 -0
  189. package/dist/elements/public/CouponCodesForm/types.js +2 -0
  190. package/dist/elements/public/CouponCodesForm/types.js.map +1 -0
  191. package/dist/elements/public/CouponForm/CouponForm.d.ts +77 -0
  192. package/dist/elements/public/CouponForm/CouponForm.js +1301 -0
  193. package/dist/elements/public/CouponForm/CouponForm.js.map +1 -0
  194. package/dist/elements/public/CouponForm/index.d.ts +19 -0
  195. package/dist/elements/public/CouponForm/index.js +21 -0
  196. package/dist/elements/public/CouponForm/index.js.map +1 -0
  197. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.d.ts +20 -0
  198. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.js +99 -0
  199. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.js.map +1 -0
  200. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.d.ts +18 -0
  201. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.js +50 -0
  202. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.js.map +1 -0
  203. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.d.ts +18 -0
  204. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.js +53 -0
  205. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.js.map +1 -0
  206. package/dist/elements/public/CouponForm/types.d.ts +27 -0
  207. package/dist/elements/public/CouponForm/types.js +2 -0
  208. package/dist/elements/public/CouponForm/types.js.map +1 -0
  209. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js +2 -1
  210. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js.map +1 -1
  211. package/dist/elements/public/Customer/Customer.js +1 -1
  212. package/dist/elements/public/Customer/Customer.js.map +1 -1
  213. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedInView.js +25 -8
  214. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedInView.js.map +1 -1
  215. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedOutView.js +20 -6
  216. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedOutView.js.map +1 -1
  217. package/dist/elements/public/CustomerPortal/InternalCustomerPortalSubscriptions.js +2 -1
  218. package/dist/elements/public/CustomerPortal/InternalCustomerPortalSubscriptions.js.map +1 -1
  219. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.d.ts +43 -0
  220. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.js +249 -0
  221. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.js.map +1 -0
  222. package/dist/elements/public/GenerateCodesForm/index.d.ts +8 -0
  223. package/dist/elements/public/GenerateCodesForm/index.js +10 -0
  224. package/dist/elements/public/GenerateCodesForm/index.js.map +1 -0
  225. package/dist/elements/public/GenerateCodesForm/types.d.ts +24 -0
  226. package/dist/elements/public/GenerateCodesForm/types.js +2 -0
  227. package/dist/elements/public/GenerateCodesForm/types.js.map +1 -0
  228. package/dist/elements/public/GiftCardCard/GiftCardCard.d.ts +26 -0
  229. package/dist/elements/public/GiftCardCard/GiftCardCard.js +95 -0
  230. package/dist/elements/public/GiftCardCard/GiftCardCard.js.map +1 -0
  231. package/dist/elements/public/GiftCardCard/index.d.ts +5 -0
  232. package/dist/elements/public/GiftCardCard/index.js +7 -0
  233. package/dist/elements/public/GiftCardCard/index.js.map +1 -0
  234. package/dist/elements/public/GiftCardCard/types.d.ts +11 -0
  235. package/dist/elements/public/GiftCardCard/types.js +2 -0
  236. package/dist/elements/public/GiftCardCard/types.js.map +1 -0
  237. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.d.ts +55 -0
  238. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js +292 -0
  239. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js.map +1 -0
  240. package/dist/elements/public/GiftCardCodeForm/index.d.ts +10 -0
  241. package/dist/elements/public/GiftCardCodeForm/index.js +12 -0
  242. package/dist/elements/public/GiftCardCodeForm/index.js.map +1 -0
  243. package/dist/elements/public/GiftCardCodeForm/types.d.ts +19 -0
  244. package/dist/elements/public/GiftCardCodeForm/types.js +2 -0
  245. package/dist/elements/public/GiftCardCodeForm/types.js.map +1 -0
  246. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.d.ts +37 -0
  247. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.js +264 -0
  248. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.js.map +1 -0
  249. package/dist/elements/public/GiftCardCodesForm/index.d.ts +9 -0
  250. package/dist/elements/public/GiftCardCodesForm/index.js +13 -0
  251. package/dist/elements/public/GiftCardCodesForm/index.js.map +1 -0
  252. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.d.ts +19 -0
  253. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.js +48 -0
  254. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.js.map +1 -0
  255. package/dist/elements/public/GiftCardCodesForm/types.d.ts +17 -0
  256. package/dist/elements/public/GiftCardCodesForm/types.js +2 -0
  257. package/dist/elements/public/GiftCardCodesForm/types.js.map +1 -0
  258. package/dist/elements/public/GiftCardForm/GiftCardForm.d.ts +67 -0
  259. package/dist/elements/public/GiftCardForm/GiftCardForm.js +684 -0
  260. package/dist/elements/public/GiftCardForm/GiftCardForm.js.map +1 -0
  261. package/dist/elements/public/GiftCardForm/currencies.d.ts +1 -0
  262. package/dist/elements/public/GiftCardForm/currencies.js +173 -0
  263. package/dist/elements/public/GiftCardForm/currencies.js.map +1 -0
  264. package/dist/elements/public/GiftCardForm/index.d.ts +18 -0
  265. package/dist/elements/public/GiftCardForm/index.js +20 -0
  266. package/dist/elements/public/GiftCardForm/index.js.map +1 -0
  267. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.d.ts +20 -0
  268. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js +99 -0
  269. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js.map +1 -0
  270. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.d.ts +18 -0
  271. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js +50 -0
  272. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js.map +1 -0
  273. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.d.ts +18 -0
  274. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js +53 -0
  275. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js.map +1 -0
  276. package/dist/elements/public/GiftCardForm/types.d.ts +28 -0
  277. package/dist/elements/public/GiftCardForm/types.js +2 -0
  278. package/dist/elements/public/GiftCardForm/types.js.map +1 -0
  279. package/dist/elements/public/I18n/I18n.js +1 -1
  280. package/dist/elements/public/I18n/I18n.js.map +1 -1
  281. package/dist/elements/public/I18n/format/date.js +7 -6
  282. package/dist/elements/public/I18n/format/date.js.map +1 -1
  283. package/dist/elements/public/I18n/format/discount.d.ts +6 -0
  284. package/dist/elements/public/I18n/format/discount.js +20 -0
  285. package/dist/elements/public/I18n/format/discount.js.map +1 -0
  286. package/dist/elements/public/I18n/format/index.js +6 -0
  287. package/dist/elements/public/I18n/format/index.js.map +1 -1
  288. package/dist/elements/public/I18n/format/ordinal.d.ts +6 -0
  289. package/dist/elements/public/I18n/format/ordinal.js +9 -0
  290. package/dist/elements/public/I18n/format/ordinal.js.map +1 -0
  291. package/dist/elements/public/I18n/format/relative.d.ts +6 -0
  292. package/dist/elements/public/I18n/format/relative.js +15 -0
  293. package/dist/elements/public/I18n/format/relative.js.map +1 -0
  294. package/dist/elements/public/NucleonElement/NucleonElement.js +4 -4
  295. package/dist/elements/public/NucleonElement/NucleonElement.js.map +1 -1
  296. package/dist/elements/public/Pagination/Pagination.d.ts +37 -0
  297. package/dist/elements/public/Pagination/Pagination.js +158 -0
  298. package/dist/elements/public/Pagination/Pagination.js.map +1 -0
  299. package/dist/elements/public/Pagination/index.d.ts +6 -0
  300. package/dist/elements/public/Pagination/index.js +8 -0
  301. package/dist/elements/public/Pagination/index.js.map +1 -0
  302. package/dist/elements/public/SignInForm/SignInForm.js +1 -1
  303. package/dist/elements/public/SignInForm/SignInForm.js.map +1 -1
  304. package/dist/elements/public/SubscriptionForm/SubscriptionForm.js +1 -1
  305. package/dist/elements/public/SubscriptionForm/SubscriptionForm.js.map +1 -1
  306. package/dist/elements/public/Table/Table.js +20 -5
  307. package/dist/elements/public/Table/Table.js.map +1 -1
  308. package/dist/elements/public/TaxForm/TaxForm.js +16 -14
  309. package/dist/elements/public/TaxForm/TaxForm.js.map +1 -1
  310. package/dist/elements/public/TemplateForm/TemplateForm.js +1 -1
  311. package/dist/elements/public/TemplateForm/TemplateForm.js.map +1 -1
  312. package/dist/elements/public/UserForm/UserForm.js +2 -1
  313. package/dist/elements/public/UserForm/UserForm.js.map +1 -1
  314. package/dist/elements/public/UsersTable/UsersTable.d.ts +5 -1
  315. package/dist/elements/public/UsersTable/UsersTable.js +2 -1
  316. package/dist/elements/public/UsersTable/UsersTable.js.map +1 -1
  317. package/dist/elements/public/index.d.ts +10 -0
  318. package/dist/elements/public/index.defined.d.ts +10 -0
  319. package/dist/elements/public/index.defined.js +10 -0
  320. package/dist/elements/public/index.defined.js.map +1 -1
  321. package/dist/elements/public/index.js +10 -0
  322. package/dist/elements/public/index.js.map +1 -1
  323. package/dist/mixins/themeable.js +96 -4
  324. package/dist/mixins/themeable.js.map +1 -1
  325. package/dist/mixins/translatable.js +1 -1
  326. package/dist/mixins/translatable.js.map +1 -1
  327. package/dist/utils/parse-duration.d.ts +1 -1
  328. package/dist/utils/parse-duration.js +7 -3
  329. package/dist/utils/parse-duration.js.map +1 -1
  330. package/package.json +3 -3
  331. package/dist/cdn/shared-07abcd7b.js +0 -1
  332. package/dist/cdn/shared-35dbd2c5.js +0 -1
  333. package/dist/cdn/shared-6b7602c7.js +0 -1
  334. package/dist/cdn/shared-87ca7818.js +0 -1
  335. package/dist/cdn/shared-9a40309d.js +0 -1
  336. package/dist/cdn/shared-ce1da35d.js +0 -1
  337. package/dist/cdn/shared-d01d809a.js +0 -1
  338. package/dist/cdn/shared-d8ffb279.js +0 -264
  339. package/dist/cdn/shared-e5cbf291.js +0 -1
  340. package/dist/cdn/shared-f1dc1c6c.js +0 -1
  341. package/dist/cdn/translations/shared/de.json +0 -271
  342. package/dist/cdn/translations/shared/en.json +0 -272
  343. package/dist/cdn/translations/shared/es.json +0 -272
@@ -0,0 +1,684 @@
1
+ import { Type } from "../QueryBuilder/types.js";
2
+ import { html } from 'lit-element';
3
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
4
+ import { CategoryRestrictionsPage } from "./private/CategoryRestrictionsPage.js";
5
+ import { ConfigurableMixin } from "../../../mixins/configurable.js";
6
+ import { EditableList } from "../../private/EditableList/EditableList.js";
7
+ import { FrequencyInput } from "../../private/FrequencyInput/FrequencyInput.js";
8
+ import { Group } from "../../private/Group/Group.js";
9
+ import { NucleonElement } from "../NucleonElement/NucleonElement.js";
10
+ import { PropertyTable } from "../../private/PropertyTable/PropertyTable.js";
11
+ import { ResponsiveMixin } from "../../../mixins/responsive.js";
12
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
13
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
14
+ import { classMap } from "../../../utils/class-map.js";
15
+ import { currencies } from "./currencies.js";
16
+ import { ifDefined } from 'lit-html/directives/if-defined';
17
+ const NS = 'gift-card-form';
18
+ const Base = ScopedElementsMixin(ThemeableMixin(ConfigurableMixin(ResponsiveMixin(TranslatableMixin(NucleonElement, NS)))));
19
+ /**
20
+ * Form element for creating or editing gift cards (`fx:gift_card`).
21
+ *
22
+ * @slot name:before
23
+ * @slot name:after
24
+ *
25
+ * @slot currency:before
26
+ * @slot currency:after
27
+ *
28
+ * @slot expires:before
29
+ * @slot expires:after
30
+ *
31
+ * @slot codes:before
32
+ * @slot codes:after
33
+ *
34
+ * @slot product-restrictions:before
35
+ * @slot product-restrictions:after
36
+ *
37
+ * @slot category-restrictions:before
38
+ * @slot category-restrictions:after
39
+ *
40
+ * @slot timestamps:before
41
+ * @slot timestamps:after
42
+ *
43
+ * @slot delete:before
44
+ * @slot delete:after
45
+ *
46
+ * @slot create:before
47
+ * @slot create:after
48
+ *
49
+ * @element foxy-gift-card-form
50
+ * @since 1.15.0
51
+ */
52
+ export class GiftCardForm extends Base {
53
+ constructor() {
54
+ super(...arguments);
55
+ this.__codesTableColumns = [
56
+ {
57
+ header: ctx => html `<foxy-i18n lang=${ctx.lang} key="code" ns=${ctx.ns}></foxy-i18n>`,
58
+ cell: ctx => html `
59
+ <vaadin-button
60
+ theme="tertiary contrast"
61
+ class="p-0"
62
+ ?disabled=${!this.in('idle') || this.disabledSelector.matches('codes', true)}
63
+ @click=${(evt) => {
64
+ const dialog = this.renderRoot.querySelector('#code-dialog');
65
+ const button = evt.currentTarget;
66
+ dialog.href = ctx.data._links.self.href;
67
+ dialog.show(button);
68
+ }}
69
+ >
70
+ <span class="font-tnum">${ctx.data.code}</span>
71
+ </vaadin-button>
72
+ `,
73
+ },
74
+ {
75
+ header: ctx => html `<foxy-i18n lang=${ctx.lang} key="date_created" ns=${ctx.ns}></foxy-i18n>`,
76
+ cell: ctx => html `
77
+ <foxy-i18n
78
+ options=${JSON.stringify({ value: ctx.data.date_created })}
79
+ class="text-tertiary"
80
+ lang=${ctx.lang}
81
+ key="date"
82
+ ns=${ctx.ns}
83
+ >
84
+ </foxy-i18n>
85
+ `,
86
+ },
87
+ {
88
+ hideBelow: 'sm',
89
+ header: c => html `<foxy-i18n lang=${c.lang} key="end_date" ns=${c.ns}></foxy-i18n>`,
90
+ cell: ctx => html `
91
+ <foxy-i18n
92
+ options=${JSON.stringify({ value: ctx.data.end_date })}
93
+ class="text-tertiary"
94
+ lang=${ctx.lang}
95
+ key="date"
96
+ ns=${ctx.ns}
97
+ >
98
+ </foxy-i18n>
99
+ `,
100
+ },
101
+ {
102
+ header: c => html `<foxy-i18n lang=${c.lang} key="current_balance" ns=${c.ns}></foxy-i18n>`,
103
+ cell: ctx => {
104
+ var _a;
105
+ return html `
106
+ <foxy-i18n
107
+ options=${JSON.stringify({
108
+ amount: `${ctx.data.current_balance} ${(_a = this.data) === null || _a === void 0 ? void 0 : _a.currency_code}`,
109
+ currencyDisplay: this.__currencyDisplay,
110
+ })}
111
+ lang=${ctx.lang}
112
+ key="price"
113
+ ns=${ctx.ns}
114
+ >
115
+ </foxy-i18n>
116
+ `;
117
+ },
118
+ },
119
+ ];
120
+ this.__codesTableQuery = null;
121
+ this.__currencyDisplay = '';
122
+ this.__itemCategories = '';
123
+ }
124
+ static get scopedElements() {
125
+ return {
126
+ 'vaadin-text-field': customElements.get('vaadin-text-field'),
127
+ 'vaadin-combo-box': customElements.get('vaadin-combo-box'),
128
+ 'vaadin-button': customElements.get('vaadin-button'),
129
+ 'iron-icon': customElements.get('iron-icon'),
130
+ 'foxy-internal-confirm-dialog': customElements.get('foxy-internal-confirm-dialog'),
131
+ 'foxy-internal-sandbox': customElements.get('foxy-internal-sandbox'),
132
+ 'foxy-query-builder': customElements.get('foxy-query-builder'),
133
+ 'foxy-form-dialog': customElements.get('foxy-form-dialog'),
134
+ 'foxy-pagination': customElements.get('foxy-pagination'),
135
+ 'foxy-spinner': customElements.get('foxy-spinner'),
136
+ 'foxy-table': customElements.get('foxy-table'),
137
+ 'foxy-i18n': customElements.get('foxy-i18n'),
138
+ 'x-category-restrictions-page': CategoryRestrictionsPage,
139
+ 'x-frequency-input': FrequencyInput,
140
+ 'x-property-table': PropertyTable,
141
+ 'x-editable-list': EditableList,
142
+ 'x-group': Group,
143
+ };
144
+ }
145
+ static get properties() {
146
+ return {
147
+ ...super.properties,
148
+ __codesTableQuery: { attribute: false },
149
+ __itemCategories: { attribute: false },
150
+ };
151
+ }
152
+ static get v8n() {
153
+ return [
154
+ ({ name: v }) => !!v || 'name_required',
155
+ ({ name: v }) => !v || v.length <= 50 || 'name_too_long',
156
+ ];
157
+ }
158
+ render() {
159
+ var _a, _b;
160
+ const hidden = this.hiddenSelector;
161
+ const isNameHidden = hidden.matches('name', true);
162
+ const isCurrencyHidden = hidden.matches('currency', true);
163
+ const isExpiresHidden = hidden.matches('expires', true);
164
+ return html `
165
+ <div class="relative space-y-l">
166
+ ${isNameHidden && isCurrencyHidden && isExpiresHidden
167
+ ? ''
168
+ : html `
169
+ <div class="grid grid-cols-1 sm-grid-cols-3 md-grid-cols-4 gap-m">
170
+ ${isNameHidden ? '' : html `<div class="md-col-span-2">${this.__renderName()}</div>`}
171
+ ${isCurrencyHidden ? '' : this.__renderCurrency()}
172
+ ${isExpiresHidden ? '' : this.__renderExpires()}
173
+ </div>
174
+ `}
175
+ ${hidden.matches('codes', true) || !this.data ? '' : this.__renderCodes()}
176
+ ${hidden.matches('product-restrictions', true) ? '' : this.__renderProductRestrictions()}
177
+ ${hidden.matches('category-restrictions', true) || !this.data
178
+ ? ''
179
+ : this.__renderCategoryRestrictions()}
180
+ ${hidden.matches('timestamps', true) ? '' : this.__renderTimestamps()}
181
+ ${hidden.matches('create', true) || !!this.data ? '' : this.__renderCreate()}
182
+ ${hidden.matches('delete', true) || !this.data ? '' : this.__renderDelete()}
183
+
184
+ <div
185
+ data-testid="spinner"
186
+ class=${classMap({
187
+ 'transition duration-500 ease-in-out absolute inset-0 flex': true,
188
+ 'opacity-0 pointer-events-none': !this.in('busy') && !this.in('fail'),
189
+ })}
190
+ >
191
+ <foxy-spinner
192
+ layout="vertical"
193
+ class="m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l"
194
+ state=${this.in('fail') ? 'error' : this.in('busy') ? 'busy' : 'empty'}
195
+ lang=${this.lang}
196
+ ns="${this.ns} ${(_b = (_a = customElements.get('foxy-spinner')) === null || _a === void 0 ? void 0 : _a.defaultNS) !== null && _b !== void 0 ? _b : ''}"
197
+ >
198
+ </foxy-spinner>
199
+ </div>
200
+ </div>
201
+ `;
202
+ }
203
+ async _sendGet() {
204
+ const giftCard = await super._sendGet();
205
+ const store = await super._fetch(giftCard._links['fx:store'].href);
206
+ const categoriesURL = new URL(store._links['fx:item_categories'].href);
207
+ categoriesURL.searchParams.set('limit', '5');
208
+ this.__currencyDisplay = store.use_international_currency_symbol ? 'code' : 'symbol';
209
+ this.__itemCategories = categoriesURL.toString();
210
+ return giftCard;
211
+ }
212
+ __getErrorMessage(prefix) {
213
+ const error = this.errors.find(err => err.startsWith(prefix));
214
+ return error ? this.t(error.replace(prefix, 'v8n')).toString() : '';
215
+ }
216
+ __getValidator(prefix) {
217
+ return () => !this.errors.some(err => err.startsWith(prefix));
218
+ }
219
+ __renderName() {
220
+ var _a;
221
+ return html `
222
+ <div>
223
+ ${this.renderTemplateOrSlot('name:before')}
224
+
225
+ <vaadin-text-field
226
+ error-message=${this.__getErrorMessage('name')}
227
+ helper-text=${this.t('gift_card_name_helper_text')}
228
+ data-testid="name"
229
+ class="w-full"
230
+ label=${this.t('name')}
231
+ .checkValidity=${this.__getValidator('name')}
232
+ .value=${(_a = this.form.name) !== null && _a !== void 0 ? _a : ''}
233
+ ?disabled=${!this.in('idle') || this.disabledSelector.matches('name', true)}
234
+ ?readonly=${this.readonlySelector.matches('name', true)}
235
+ required
236
+ @keydown=${(evt) => evt.key === 'Enter' && this.submit()}
237
+ @input=${(evt) => {
238
+ const newName = evt.currentTarget.value;
239
+ this.edit({ name: newName });
240
+ }}
241
+ >
242
+ </vaadin-text-field>
243
+
244
+ ${this.renderTemplateOrSlot('name:after')}
245
+ </div>
246
+ `;
247
+ }
248
+ __renderCurrency() {
249
+ var _a, _b;
250
+ return html `
251
+ <div>
252
+ ${this.renderTemplateOrSlot('currency:before')}
253
+
254
+ <vaadin-combo-box
255
+ item-label-path="label"
256
+ item-value-path="value"
257
+ item-id-path="value"
258
+ data-testid="currency"
259
+ class="w-full"
260
+ label=${this.t('currency')}
261
+ ?disabled=${!this.in('idle') || this.disabledSelector.matches('currency', true)}
262
+ ?readonly=${this.readonlySelector.matches('currency', true)}
263
+ .value=${(_b = (_a = this.form.currency_code) === null || _a === void 0 ? void 0 : _a.toLowerCase()) !== null && _b !== void 0 ? _b : ''}
264
+ .items=${currencies.map(code => ({
265
+ label: `${this.t(`currency_${code}`)} (${code.toUpperCase()})`,
266
+ value: code,
267
+ }))}
268
+ @change=${(evt) => {
269
+ const comboBox = evt.currentTarget;
270
+ this.edit({ currency_code: comboBox.value });
271
+ }}
272
+ >
273
+ </vaadin-combo-box>
274
+
275
+ ${this.renderTemplateOrSlot('currency:after')}
276
+ </div>
277
+ `;
278
+ }
279
+ __renderExpires() {
280
+ var _a;
281
+ return html `
282
+ <div>
283
+ ${this.renderTemplateOrSlot('expires:before')}
284
+
285
+ <x-frequency-input
286
+ placeholder=${this.t('select')}
287
+ data-testid="expires"
288
+ label=${this.t('expires_after')}
289
+ class="w-full"
290
+ lang=${this.lang}
291
+ ns=${this.ns}
292
+ ?disabled=${!this.in('idle') || this.disabledSelector.matches('expires', true)}
293
+ ?readonly=${this.readonlySelector.matches('expires', true)}
294
+ .value=${(_a = this.form.expires_after) !== null && _a !== void 0 ? _a : ''}
295
+ @change=${(evt) => {
296
+ const input = evt.currentTarget;
297
+ this.edit({ expires_after: input.value });
298
+ }}
299
+ >
300
+ </x-frequency-input>
301
+
302
+ ${this.renderTemplateOrSlot('expires:after')}
303
+ </div>
304
+ `;
305
+ }
306
+ __renderCodes() {
307
+ var _a, _b, _c, _d, _e;
308
+ const { disabledSelector, readonlySelector, hiddenSelector, group, data, lang, ns } = this;
309
+ const isDisabled = !this.in('idle') || disabledSelector.matches('codes', true);
310
+ const filters = this.__codesTableQuery;
311
+ const url = new URL(data._links['fx:gift_card_codes'].href);
312
+ new URLSearchParams(filters !== null && filters !== void 0 ? filters : '').forEach((value, name) => url.searchParams.set(name, value));
313
+ url.searchParams.set('limit', '5');
314
+ const filterButtonLabel = filters === null ? 'filter' : 'clear_filters';
315
+ const filterButtonIcon = `icons:${filters === null ? 'filter-list' : 'clear'}`;
316
+ return html `
317
+ <div data-testid="codes">
318
+ <foxy-form-dialog
319
+ disabledcontrols=${disabledSelector.zoom('codes:generate:form').toString()}
320
+ readonlycontrols=${readonlySelector.zoom('codes:generate:form').toString()}
321
+ hiddencontrols="save-button ${hiddenSelector.zoom('codes:generate:form').toString()}"
322
+ header="generate"
323
+ parent=${(_a = data === null || data === void 0 ? void 0 : data._links['fx:generate_codes'].href) !== null && _a !== void 0 ? _a : ''}
324
+ group=${group}
325
+ lang=${lang}
326
+ form="foxy-generate-codes-form"
327
+ ns=${ns}
328
+ id="generate-codes-dialog"
329
+ alert
330
+ .related=${[url.toString()]}
331
+ >
332
+ </foxy-form-dialog>
333
+
334
+ <foxy-form-dialog
335
+ disabledcontrols=${disabledSelector.zoom('codes:form').toString()}
336
+ readonlycontrols=${readonlySelector.zoom('codes:form').toString()}
337
+ hiddencontrols=${hiddenSelector.zoom('codes:form').toString()}
338
+ header="code"
339
+ parent=${url.toString()}
340
+ group=${group}
341
+ lang=${lang}
342
+ form="foxy-gift-card-code-form"
343
+ ns=${ns}
344
+ id="code-dialog"
345
+ >
346
+ </foxy-form-dialog>
347
+
348
+ <foxy-form-dialog
349
+ disabledcontrols=${disabledSelector.zoom('codes:import:form').toString()}
350
+ readonlycontrols=${readonlySelector.zoom('codes:import:form').toString()}
351
+ hiddencontrols="save-button ${hiddenSelector.zoom('codes:import:form').toString()}"
352
+ header="import"
353
+ parent=${data._links['fx:gift_card_codes'].href}
354
+ group=${group}
355
+ lang=${lang}
356
+ form="foxy-gift-card-codes-form"
357
+ ns=${ns}
358
+ id="import-dialog"
359
+ >
360
+ </foxy-form-dialog>
361
+
362
+ ${this.renderTemplateOrSlot('codes:before')}
363
+
364
+ <div class="flex items-center justify-between mb-xs space-x-s">
365
+ <foxy-i18n
366
+ class="text-s font-medium text-secondary leading-none flex-1"
367
+ lang=${lang}
368
+ key="code_plural"
369
+ ns=${ns}
370
+ >
371
+ </foxy-i18n>
372
+
373
+ <vaadin-button
374
+ data-testid="codes:generate-button"
375
+ theme="success tertiary small"
376
+ ?disabled=${isDisabled}
377
+ @click=${(evt) => {
378
+ const dialog = this.renderRoot.querySelector('#generate-codes-dialog');
379
+ const button = evt.currentTarget;
380
+ dialog === null || dialog === void 0 ? void 0 : dialog.show(button);
381
+ }}
382
+ >
383
+ <foxy-i18n class="text-s" lang=${lang} key="generate" ns=${ns}></foxy-i18n>
384
+ <iron-icon class="icon-inline text-s" icon="icons:add"></iron-icon>
385
+ </vaadin-button>
386
+
387
+ <vaadin-button
388
+ data-testid="codes:import-button"
389
+ theme="contrast tertiary small"
390
+ ?disabled=${isDisabled}
391
+ @click=${(evt) => {
392
+ const dialog = this.renderRoot.querySelector('#import-dialog');
393
+ const button = evt.currentTarget;
394
+ dialog === null || dialog === void 0 ? void 0 : dialog.show(button);
395
+ }}
396
+ >
397
+ <foxy-i18n class="text-s" lang=${lang} key="import" ns=${ns}></foxy-i18n>
398
+ <iron-icon class="icon-inline text-s" icon="icons:open-in-browser"></iron-icon>
399
+ </vaadin-button>
400
+
401
+ <vaadin-button
402
+ data-testid="codes:filter-button"
403
+ theme="contrast ${filters === null ? 'tertiary' : ''} small"
404
+ ?disabled=${isDisabled}
405
+ @click=${() => (this.__codesTableQuery = filters === null ? '' : null)}
406
+ >
407
+ <foxy-i18n class="text-s" lang=${lang} key=${filterButtonLabel} ns=${ns}></foxy-i18n>
408
+ <iron-icon class="icon-inline text-s" icon=${filterButtonIcon}></iron-icon>
409
+ </vaadin-button>
410
+ </div>
411
+
412
+ <foxy-query-builder
413
+ class="bg-contrast-5 rounded-tl-l rounded-tr-s rounded-b-l p-m mb-s"
414
+ lang=${lang}
415
+ ns="${ns} ${(_c = (_b = customElements.get('foxy-query-builder')) === null || _b === void 0 ? void 0 : _b.defaultNS) !== null && _c !== void 0 ? _c : ''}"
416
+ ?disabled=${isDisabled}
417
+ ?hidden=${filters === null}
418
+ .options=${GiftCardForm.__codesQueryOptions}
419
+ .value=${filters !== null && filters !== void 0 ? filters : ''}
420
+ @change=${(evt) => {
421
+ const queryBuilder = evt.currentTarget;
422
+ this.__codesTableQuery = queryBuilder.value;
423
+ }}
424
+ >
425
+ </foxy-query-builder>
426
+
427
+ <foxy-pagination
428
+ first=${url.toString()}
429
+ lang=${lang}
430
+ ns="${ns} ${(_e = (_d = customElements.get('foxy-pagination')) === null || _d === void 0 ? void 0 : _d.defaultNS) !== null && _e !== void 0 ? _e : ''}"
431
+ ?disabled=${isDisabled}
432
+ >
433
+ <foxy-table
434
+ class="px-m mb-s border border-contrast-10 rounded-t-l rounded-b-l"
435
+ group=${group}
436
+ lang=${lang}
437
+ ns=${ns}
438
+ .columns=${this.__codesTableColumns}
439
+ >
440
+ </foxy-table>
441
+ </foxy-pagination>
442
+
443
+ ${this.renderTemplateOrSlot('codes:after')}
444
+ </div>
445
+ `;
446
+ }
447
+ __renderProductRestrictions() {
448
+ var _a;
449
+ const scope = 'product-restrictions';
450
+ const isDisabled = !this.in('idle') || this.disabledSelector.matches(scope, true);
451
+ const isReadonly = this.readonlySelector.matches(scope, true);
452
+ const restrictions = (_a = this.form.product_code_restrictions) !== null && _a !== void 0 ? _a : '';
453
+ const groups = [
454
+ { header: 'allow', items: [] },
455
+ { header: 'block', items: [] },
456
+ ];
457
+ if (restrictions) {
458
+ restrictions.split(',').forEach(value => {
459
+ const isBlocklistValue = value.startsWith('-');
460
+ const target = isBlocklistValue ? 1 : 0;
461
+ const label = isBlocklistValue ? value.substring(1) : value;
462
+ groups[target].items.push({ label, value });
463
+ });
464
+ }
465
+ return html `
466
+ <div data-testid="product-restrictions">
467
+ ${this.renderTemplateOrSlot('product-restrictions:before')}
468
+
469
+ <div class="space-y-s">
470
+ <x-group frame>
471
+ <foxy-i18n
472
+ class=${isDisabled ? 'text-disabled' : 'text-secondary'}
473
+ slot="header"
474
+ lang=${this.lang}
475
+ key="product_restrictions"
476
+ ns=${this.ns}
477
+ >
478
+ </foxy-i18n>
479
+
480
+ <div class="grid sm-grid-cols-2 bg-contrast-10" style="gap: 1px">
481
+ ${groups.map((group, index) => {
482
+ return html `
483
+ <x-group class="bg-base pt-m">
484
+ <foxy-i18n
485
+ class=${isDisabled ? 'text-disabled' : 'text-tertiary'}
486
+ slot="header"
487
+ lang=${this.lang}
488
+ key=${group.header}
489
+ ns=${this.ns}
490
+ >
491
+ </foxy-i18n>
492
+
493
+ <x-editable-list
494
+ data-testid="product-restrictions:${group.header}"
495
+ lang=${this.lang}
496
+ ns=${this.ns}
497
+ ?disabled=${isDisabled}
498
+ ?readonly=${isReadonly}
499
+ .items=${group.items}
500
+ @change=${(evt) => {
501
+ const newItemsByGroup = [
502
+ index === 0 ? evt.currentTarget.items : groups[0].items,
503
+ index === 1 ? evt.currentTarget.items : groups[1].items,
504
+ ];
505
+ const newSanitizedItemsByGroup = newItemsByGroup
506
+ .map(list => list.map(v => v.value.replace(/^[\s-]*/, '').trimEnd()))
507
+ .map(list => list.filter(v => !!v))
508
+ .map(list => Array.from(new Set(list)));
509
+ const newRestrictions = newSanitizedItemsByGroup[0]
510
+ .concat(newSanitizedItemsByGroup[1].map(v => `-${v}`))
511
+ .join(',');
512
+ this.edit({ product_code_restrictions: newRestrictions });
513
+ }}
514
+ >
515
+ </x-editable-list>
516
+ </x-group>
517
+ `;
518
+ })}
519
+ </div>
520
+ </x-group>
521
+
522
+ <foxy-i18n
523
+ class=${classMap({
524
+ 'block text-xs leading-s transition-colors': true,
525
+ 'text-secondary': !isDisabled,
526
+ 'text-disabled': isDisabled,
527
+ })}
528
+ lang=${this.lang}
529
+ key="gift_card_product_restrictions_explainer"
530
+ ns=${this.ns}
531
+ >
532
+ </foxy-i18n>
533
+ </div>
534
+
535
+ ${this.renderTemplateOrSlot('product-restrictions:after')}
536
+ </div>
537
+ `;
538
+ }
539
+ __renderCategoryRestrictions() {
540
+ var _a, _b, _c;
541
+ const scope = 'category-restrictions';
542
+ const isDisabled = !this.in('idle') || this.disabledSelector.matches(scope, true);
543
+ const isReadonly = this.readonlySelector.matches(scope, true);
544
+ const giftCardItemCategories = (_a = this.data) === null || _a === void 0 ? void 0 : _a._links['fx:gift_card_item_categories'].href;
545
+ return html `
546
+ <div data-testid="category-restrictions">
547
+ ${this.renderTemplateOrSlot(`${scope}:before`)}
548
+
549
+ <div class="space-y-xs">
550
+ <foxy-pagination
551
+ first=${this.__itemCategories}
552
+ lang=${this.lang}
553
+ ns="${this.ns} ${(_c = (_b = customElements.get('foxy-pagination')) === null || _b === void 0 ? void 0 : _b.defaultNS) !== null && _c !== void 0 ? _c : ''}"
554
+ ?disabled=${isDisabled}
555
+ >
556
+ <foxy-i18n
557
+ class="block text-s font-medium text-secondary leading-none mb-s"
558
+ lang=${this.lang}
559
+ key="category_restrictions"
560
+ ns=${this.ns}
561
+ >
562
+ </foxy-i18n>
563
+
564
+ <x-category-restrictions-page
565
+ gift-card-item-categories=${ifDefined(giftCardItemCategories)}
566
+ data-testid="category-restrictions:page"
567
+ gift-card=${this.href}
568
+ class="border border-contrast-10 rounded-t-l rounded-b-l mb-s"
569
+ group=${this.group}
570
+ lang=${this.lang}
571
+ ns=${this.ns}
572
+ ?disabled=${isDisabled}
573
+ ?readonly=${isReadonly}
574
+ >
575
+ </x-category-restrictions-page>
576
+ </foxy-pagination>
577
+
578
+ <foxy-i18n
579
+ class="block text-xs leading-s text-secondary"
580
+ lang=${this.lang}
581
+ key="gift_card_category_restrictions_helper_text"
582
+ ns=${this.ns}
583
+ >
584
+ </foxy-i18n>
585
+ </div>
586
+
587
+ ${this.renderTemplateOrSlot(`${scope}:after`)}
588
+ </div>
589
+ `;
590
+ }
591
+ __renderTimestamps() {
592
+ return html `
593
+ <div>
594
+ ${this.renderTemplateOrSlot('timestamps:before')}
595
+
596
+ <x-property-table
597
+ data-testid="timestamps"
598
+ .items=${['date_modified', 'date_created'].map(field => {
599
+ var _a;
600
+ return ({
601
+ name: this.t(field),
602
+ value: ((_a = this.data) === null || _a === void 0 ? void 0 : _a[field]) ? this.t('date', { value: new Date(this.data[field]) })
603
+ : '',
604
+ });
605
+ })}
606
+ >
607
+ </x-property-table>
608
+
609
+ ${this.renderTemplateOrSlot('timestamps:after')}
610
+ </div>
611
+ `;
612
+ }
613
+ __renderCreate() {
614
+ const isCleanTemplateInvalid = this.in({ idle: { template: { clean: 'invalid' } } });
615
+ const isDirtyTemplateInvalid = this.in({ idle: { template: { dirty: 'invalid' } } });
616
+ const isCleanSnapshotInvalid = this.in({ idle: { snapshot: { clean: 'invalid' } } });
617
+ const isDirtySnapshotInvalid = this.in({ idle: { snapshot: { dirty: 'invalid' } } });
618
+ const isTemplateInvalid = isCleanTemplateInvalid || isDirtyTemplateInvalid;
619
+ const isSnaphotInvalid = isCleanSnapshotInvalid || isDirtySnapshotInvalid;
620
+ const isInvalid = isTemplateInvalid || isSnaphotInvalid;
621
+ const isBusy = this.in('busy');
622
+ return html `
623
+ <div>
624
+ ${this.renderTemplateOrSlot('create:before')}
625
+
626
+ <vaadin-button
627
+ data-testid="create"
628
+ class="w-full"
629
+ theme="primary success"
630
+ ?disabled=${isBusy || isInvalid || this.disabledSelector.matches('create', true)}
631
+ @click=${this.submit}
632
+ >
633
+ <foxy-i18n ns=${this.ns} key="create" lang=${this.lang}></foxy-i18n>
634
+ </vaadin-button>
635
+
636
+ ${this.renderTemplateOrSlot('create:after')}
637
+ </div>
638
+ `;
639
+ }
640
+ __renderDelete() {
641
+ return html `
642
+ <div>
643
+ <foxy-internal-confirm-dialog
644
+ data-testid="confirm"
645
+ message="delete_prompt"
646
+ confirm="delete"
647
+ cancel="cancel"
648
+ header="delete"
649
+ theme="primary error"
650
+ lang=${this.lang}
651
+ ns=${this.ns}
652
+ id="confirm"
653
+ @hide=${(evt) => !evt.detail.cancelled && this.delete()}
654
+ >
655
+ </foxy-internal-confirm-dialog>
656
+
657
+ ${this.renderTemplateOrSlot('delete:before')}
658
+
659
+ <vaadin-button
660
+ data-testid="delete"
661
+ theme="primary error"
662
+ class="w-full"
663
+ ?disabled=${!this.in('idle') || this.disabledSelector.matches('delete', true)}
664
+ @click=${(evt) => {
665
+ const confirm = this.renderRoot.querySelector('#confirm');
666
+ confirm.show(evt.currentTarget);
667
+ }}
668
+ >
669
+ <foxy-i18n ns=${this.ns} key="delete" lang=${this.lang}></foxy-i18n>
670
+ </vaadin-button>
671
+
672
+ ${this.renderTemplateOrSlot('delete:after')}
673
+ </div>
674
+ `;
675
+ }
676
+ }
677
+ GiftCardForm.__codesQueryOptions = [
678
+ { label: 'code', path: 'code', type: Type.String },
679
+ { label: 'current_balance', path: 'current_balance', type: Type.Number },
680
+ { label: 'end_date', path: 'end_date', type: Type.Date },
681
+ { label: 'date_created', path: 'date_created', type: Type.Date },
682
+ { label: 'date_modified', path: 'date_modified', type: Type.Date },
683
+ ];
684
+ //# sourceMappingURL=GiftCardForm.js.map