@foxy.io/elements 1.15.0-beta.3 → 1.15.0-beta.6

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 (181) 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 -1
  11. package/dist/cdn/foxy-coupon-code-form.js +1 -1
  12. package/dist/cdn/foxy-coupon-codes-form.js +1 -1
  13. package/dist/cdn/foxy-coupon-form.js +1 -1
  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 -169
  20. package/dist/cdn/foxy-customer-portal.js +2 -2
  21. package/dist/cdn/foxy-customer.js +1 -1
  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 -1
  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 -1
  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 -1
  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 +1 -1
  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-9af7b5f0.js → shared-02945b27.js} +1 -1
  55. package/dist/cdn/{shared-a8d96c23.js → shared-06e64d75.js} +1 -1
  56. package/dist/cdn/{shared-b03b6d72.js → shared-07049bfe.js} +1 -1
  57. package/dist/cdn/{shared-ccea5a33.js → shared-08c63028.js} +1 -1
  58. package/dist/cdn/shared-09069d7c.js +1 -0
  59. package/dist/cdn/shared-11708514.js +1 -0
  60. package/dist/cdn/{shared-a11160e7.js → shared-20b9ce70.js} +1 -1
  61. package/dist/cdn/{shared-d3831f99.js → shared-21419f10.js} +1 -1
  62. package/dist/cdn/shared-25e67340.js +302 -0
  63. package/dist/cdn/{shared-423a4840.js → shared-39e3ae67.js} +1 -1
  64. package/dist/cdn/shared-3be96355.js +1 -0
  65. package/dist/cdn/{shared-51b5e223.js → shared-40b5267a.js} +1 -1
  66. package/dist/cdn/{shared-fb403e1f.js → shared-448781f9.js} +1 -1
  67. package/dist/cdn/{shared-8f7a66c4.js → shared-4dc6d228.js} +1 -1
  68. package/dist/cdn/shared-5272c758.js +1 -0
  69. package/dist/cdn/{shared-c1dadefe.js → shared-5535f38f.js} +1 -1
  70. package/dist/cdn/shared-66633ff7.js +1 -0
  71. package/dist/cdn/{shared-30131f76.js → shared-756034e4.js} +1 -1
  72. package/dist/cdn/shared-7f0a9790.js +1 -0
  73. package/dist/cdn/{shared-6b7602c7.js → shared-805d18a2.js} +1 -1
  74. package/dist/cdn/shared-940a4826.js +1 -0
  75. package/dist/cdn/{shared-b2330475.js → shared-a23cf7c8.js} +1 -1
  76. package/dist/cdn/{shared-0bda8ecb.js → shared-a7095b6a.js} +1 -1
  77. package/dist/cdn/{shared-a4e6ecb0.js → shared-b9f18aaa.js} +1 -1
  78. package/dist/cdn/{shared-51e28c83.js → shared-df730f90.js} +1 -1
  79. package/dist/cdn/{shared-4038cb18.js → shared-e209cb55.js} +1 -1
  80. package/dist/cdn/{shared-cd3c902e.js → shared-e68b9c83.js} +1 -1
  81. package/dist/cdn/{shared-ff149b55.js → shared-ffb27563.js} +1 -1
  82. package/dist/cdn/translations/shared/en.json +180 -0
  83. package/dist/elements/private/EditableList/EditableList.js +1 -0
  84. package/dist/elements/private/EditableList/EditableList.js.map +1 -1
  85. package/dist/elements/private/FrequencyInput/FrequencyInput.d.ts +2 -1
  86. package/dist/elements/private/FrequencyInput/FrequencyInput.js +3 -1
  87. package/dist/elements/private/FrequencyInput/FrequencyInput.js.map +1 -1
  88. package/dist/elements/public/CollectionPage/CollectionPage.js +3 -1
  89. package/dist/elements/public/CollectionPage/CollectionPage.js.map +1 -1
  90. package/dist/elements/public/CollectionPage/types.d.ts +2 -0
  91. package/dist/elements/public/CollectionPage/types.js.map +1 -1
  92. package/dist/elements/public/CouponCard/CouponCard.js +5 -5
  93. package/dist/elements/public/CouponCard/CouponCard.js.map +1 -1
  94. package/dist/elements/public/CouponCodesForm/CouponCodesForm.d.ts +2 -0
  95. package/dist/elements/public/CouponCodesForm/CouponCodesForm.js +7 -1
  96. package/dist/elements/public/CouponCodesForm/CouponCodesForm.js.map +1 -1
  97. package/dist/elements/public/CouponCodesForm/types.d.ts +3 -2
  98. package/dist/elements/public/CouponCodesForm/types.js.map +1 -1
  99. package/dist/elements/public/CouponForm/CouponForm.js +3 -3
  100. package/dist/elements/public/CouponForm/CouponForm.js.map +1 -1
  101. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.d.ts +4 -0
  102. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.js +32 -0
  103. package/dist/elements/public/GenerateCodesForm/GenerateCodesForm.js.map +1 -1
  104. package/dist/elements/public/GiftCardCard/GiftCardCard.d.ts +26 -0
  105. package/dist/elements/public/GiftCardCard/GiftCardCard.js +95 -0
  106. package/dist/elements/public/GiftCardCard/GiftCardCard.js.map +1 -0
  107. package/dist/elements/public/GiftCardCard/index.d.ts +5 -0
  108. package/dist/elements/public/GiftCardCard/index.js +7 -0
  109. package/dist/elements/public/GiftCardCard/index.js.map +1 -0
  110. package/dist/elements/public/GiftCardCard/types.d.ts +11 -0
  111. package/dist/elements/public/GiftCardCard/types.js +2 -0
  112. package/dist/elements/public/GiftCardCard/types.js.map +1 -0
  113. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.d.ts +55 -0
  114. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js +292 -0
  115. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js.map +1 -0
  116. package/dist/elements/public/GiftCardCodeForm/index.d.ts +10 -0
  117. package/dist/elements/public/GiftCardCodeForm/index.js +12 -0
  118. package/dist/elements/public/GiftCardCodeForm/index.js.map +1 -0
  119. package/dist/elements/public/GiftCardCodeForm/types.d.ts +19 -0
  120. package/dist/elements/public/GiftCardCodeForm/types.js +2 -0
  121. package/dist/elements/public/GiftCardCodeForm/types.js.map +1 -0
  122. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.d.ts +37 -0
  123. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.js +259 -0
  124. package/dist/elements/public/GiftCardCodesForm/GiftCardCodesForm.js.map +1 -0
  125. package/dist/elements/public/GiftCardCodesForm/index.d.ts +9 -0
  126. package/dist/elements/public/GiftCardCodesForm/index.js +13 -0
  127. package/dist/elements/public/GiftCardCodesForm/index.js.map +1 -0
  128. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.d.ts +19 -0
  129. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.js +48 -0
  130. package/dist/elements/public/GiftCardCodesForm/internal/InternalGiftCardCodesFormListItem.js.map +1 -0
  131. package/dist/elements/public/GiftCardCodesForm/types.d.ts +17 -0
  132. package/dist/elements/public/GiftCardCodesForm/types.js +2 -0
  133. package/dist/elements/public/GiftCardCodesForm/types.js.map +1 -0
  134. package/dist/elements/public/GiftCardForm/GiftCardForm.d.ts +67 -0
  135. package/dist/elements/public/GiftCardForm/GiftCardForm.js +666 -0
  136. package/dist/elements/public/GiftCardForm/GiftCardForm.js.map +1 -0
  137. package/dist/elements/public/GiftCardForm/currencies.d.ts +1 -0
  138. package/dist/elements/public/GiftCardForm/currencies.js +173 -0
  139. package/dist/elements/public/GiftCardForm/currencies.js.map +1 -0
  140. package/dist/elements/public/GiftCardForm/index.d.ts +18 -0
  141. package/dist/elements/public/GiftCardForm/index.js +20 -0
  142. package/dist/elements/public/GiftCardForm/index.js.map +1 -0
  143. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.d.ts +20 -0
  144. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js +99 -0
  145. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js.map +1 -0
  146. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.d.ts +20 -0
  147. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js +52 -0
  148. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js.map +1 -0
  149. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.d.ts +20 -0
  150. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js +53 -0
  151. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js.map +1 -0
  152. package/dist/elements/public/GiftCardForm/types.d.ts +28 -0
  153. package/dist/elements/public/GiftCardForm/types.js +2 -0
  154. package/dist/elements/public/GiftCardForm/types.js.map +1 -0
  155. package/dist/elements/public/I18n/format/index.js +2 -0
  156. package/dist/elements/public/I18n/format/index.js.map +1 -1
  157. package/dist/elements/public/I18n/format/relative.d.ts +6 -0
  158. package/dist/elements/public/I18n/format/relative.js +15 -0
  159. package/dist/elements/public/I18n/format/relative.js.map +1 -0
  160. package/dist/elements/public/NucleonElement/NucleonElement.js +4 -4
  161. package/dist/elements/public/NucleonElement/NucleonElement.js.map +1 -1
  162. package/dist/elements/public/index.d.ts +4 -0
  163. package/dist/elements/public/index.defined.d.ts +4 -0
  164. package/dist/elements/public/index.defined.js +4 -0
  165. package/dist/elements/public/index.defined.js.map +1 -1
  166. package/dist/elements/public/index.js +4 -0
  167. package/dist/elements/public/index.js.map +1 -1
  168. package/dist/mixins/themeable.js +12 -0
  169. package/dist/mixins/themeable.js.map +1 -1
  170. package/dist/utils/parse-duration.d.ts +1 -1
  171. package/dist/utils/parse-duration.js +7 -3
  172. package/dist/utils/parse-duration.js.map +1 -1
  173. package/package.json +2 -2
  174. package/dist/cdn/shared-0fcdd1c4.js +0 -1
  175. package/dist/cdn/shared-4fa5f144.js +0 -1
  176. package/dist/cdn/shared-710ed658.js +0 -134
  177. package/dist/cdn/shared-800a5471.js +0 -1
  178. package/dist/cdn/shared-87ca7818.js +0 -1
  179. package/dist/cdn/shared-c6a4b2d6.js +0 -1
  180. package/dist/cdn/shared-d9a260f0.js +0 -1
  181. package/dist/cdn/shared-f875a4f8.js +0 -1
@@ -18,6 +18,9 @@ const Base = ConfigurableMixin(ThemeableMixin(TranslatableMixin(NucleonElement,
18
18
  * @slot prefix:before
19
19
  * @slot prefix:after
20
20
  *
21
+ * @slot current-balance:before
22
+ * @slot current-balance:after
23
+ *
21
24
  * @slot generate:before
22
25
  * @slot generate:after
23
26
  *
@@ -32,6 +35,7 @@ export class GenerateCodesForm extends Base {
32
35
  static get v8n() {
33
36
  return [
34
37
  ({ number_of_codes: v }) => (v && v > 0) || 'number_of_codes_required',
38
+ ({ current_balance: v }) => !v || v >= 0 || 'current_balance_negative',
35
39
  ({ length: v }) => (v && v > 0) || 'length_required',
36
40
  ];
37
41
  }
@@ -55,6 +59,7 @@ export class GenerateCodesForm extends Base {
55
59
  >
56
60
  ${hiddenSelector.matches('length', true) ? '' : this.__renderLength()}
57
61
  ${hiddenSelector.matches('number-of-codes', true) ? '' : this.__renderNumberOfCodes()}
62
+ ${hiddenSelector.matches('current-balance', true) ? '' : this.__renderCurrentBalance()}
58
63
  ${hiddenSelector.matches('prefix', true) ? '' : this.__renderPrefix()}
59
64
  ${hiddenSelector.matches('generate', true) ? '' : this.__renderGenerate()}
60
65
  </div>
@@ -152,6 +157,33 @@ export class GenerateCodesForm extends Base {
152
157
  ${this.renderTemplateOrSlot('number-of-codes:after')}
153
158
  `;
154
159
  }
160
+ __renderCurrentBalance() {
161
+ var _a;
162
+ const isTemplate = this.in({ idle: 'template' });
163
+ return html `
164
+ ${this.renderTemplateOrSlot('current-balance:before')}
165
+
166
+ <vaadin-integer-field
167
+ error-message=${this.__getErrorMessage('current_balance')}
168
+ label=${this.t('balance')}
169
+ class="w-full col-span-2"
170
+ min="0"
171
+ ?disabled=${!isTemplate || this.disabledSelector.matches('current-balance', true)}
172
+ ?readonly=${this.readonlySelector.matches('current-balance', true)}
173
+ prevent-invalid-input
174
+ has-controls
175
+ .checkValidity=${this.__getValidator('current_balance')}
176
+ .value=${isTemplate ? (_a = this.form.current_balance) !== null && _a !== void 0 ? _a : 0 : ''}
177
+ @change=${(evt) => {
178
+ const field = evt.currentTarget;
179
+ this.edit({ current_balance: parseInt(field.value) });
180
+ }}
181
+ >
182
+ </vaadin-integer-field>
183
+
184
+ ${this.renderTemplateOrSlot('current-balance:after')}
185
+ `;
186
+ }
155
187
  __renderPrefix() {
156
188
  const isTemplate = this.in({ idle: 'template' });
157
189
  return html `
@@ -1 +1 @@
1
- {"version":3,"file":"GenerateCodesForm.js","sourceRoot":"","sources":["../../../../src/elements/public/GenerateCodesForm/GenerateCodesForm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Data, Templates } from './types';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { IntegerFieldElement } from '@vaadin/vaadin-text-field/vaadin-integer-field';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { NucleonV8N } from '../NucleonElement/types';\nimport { TextFieldElement } from '@vaadin/vaadin-text-field/vaadin-text-field';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\n\nconst NS = 'generate-codes';\nconst Base = ConfigurableMixin(ThemeableMixin(TranslatableMixin(NucleonElement, NS)));\n\n/**\n * Form element for generating codes for coupons or gift cards (`fx:generate_codes`).\n *\n * @slot length:before\n * @slot length:after\n *\n * @slot number-of-codes:before\n * @slot number-of-codes:after\n *\n * @slot prefix:before\n * @slot prefix:after\n *\n * @slot generate:before\n * @slot generate:after\n *\n * @element foxy-generate-codes-form\n * @since 1.15.0\n */\nexport class GenerateCodesForm extends Base<Data> {\n static get v8n(): NucleonV8N<Data> {\n return [\n ({ number_of_codes: v }) => (v && v > 0) || 'number_of_codes_required',\n ({ length: v }) => (v && v > 0) || 'length_required',\n ];\n }\n\n templates: Templates = {};\n\n render(): TemplateResult {\n const { hiddenSelector, lang, ns } = this;\n\n const isBusy = this.in('busy');\n const isFail = this.in('fail');\n const isSnapshot = this.in({ idle: 'snapshot' });\n const isTemplate = this.in({ idle: 'template' });\n\n const transition = 'transition-opacity duration-500';\n const hidden = 'opacity-0 pointer-events-none';\n\n return html`\n <div aria-busy=${isBusy} aria-live=\"polite\" class=\"relative\">\n <div\n class=${classMap({\n 'grid grid-cols-2 gap-m': true,\n [transition]: true,\n [hidden]: isSnapshot,\n })}\n >\n ${hiddenSelector.matches('length', true) ? '' : this.__renderLength()}\n ${hiddenSelector.matches('number-of-codes', true) ? '' : this.__renderNumberOfCodes()}\n ${hiddenSelector.matches('prefix', true) ? '' : this.__renderPrefix()}\n ${hiddenSelector.matches('generate', true) ? '' : this.__renderGenerate()}\n </div>\n\n <div\n class=${classMap({\n 'absolute inset-0 flex flex-col items-center justify-center': true,\n 'text-center text-m text-secondary leading-m': true,\n [transition]: true,\n [hidden]: !isSnapshot,\n })}\n >\n <div class=\"mx-auto flex mb-m w-l h-l rounded-t-l rounded-b-l bg-success\">\n <iron-icon icon=\"icons:done-all\" class=\"m-auto text-success-contrast\"></iron-icon>\n </div>\n\n <foxy-i18n class=\"block\" lang=${lang} key=\"generate_codes_done\" ns=${ns}></foxy-i18n>\n </div>\n\n <div\n class=${classMap({\n 'absolute inset-0 flex': true,\n [transition]: true,\n [hidden]: !isBusy && !isFail,\n })}\n >\n <foxy-spinner\n layout=\"vertical\"\n class=\"m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l\"\n state=${isFail ? 'error' : isTemplate ? 'empty' : 'busy'}\n lang=${lang}\n ns=\"${ns} ${customElements.get('foxy-spinner')?.defaultNS ?? ''}\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n\n private __getErrorMessage(prefix: string) {\n const error = this.errors.find(err => err.startsWith(prefix));\n return error ? this.t(error.replace(prefix, 'v8n')) : '';\n }\n\n private __getValidator(prefix: string) {\n return () => !this.errors.some(err => err.startsWith(prefix));\n }\n\n private __renderLength() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('length:before')}\n\n <vaadin-integer-field\n error-message=${this.__getErrorMessage('length')}\n label=${this.t('length')}\n class=\"w-full\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('length', true)}\n ?readonly=${this.readonlySelector.matches('length', true)}\n prevent-invalid-input\n has-controls\n .checkValidity=${this.__getValidator('length')}\n .value=${isTemplate ? this.form.length : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as IntegerFieldElement;\n this.edit({ length: parseInt(field.value) });\n }}\n >\n </vaadin-integer-field>\n\n ${this.renderTemplateOrSlot('length:after')}\n `;\n }\n\n private __renderNumberOfCodes() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('number-of-codes:before')}\n\n <vaadin-integer-field\n error-message=${this.__getErrorMessage('number_of_codes')}\n label=${this.t('number_of_codes')}\n class=\"w-full\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('number-of-codes', true)}\n ?readonly=${this.readonlySelector.matches('number-of-codes', true)}\n prevent-invalid-input\n has-controls\n .checkValidity=${this.__getValidator('number_of_codes')}\n .value=${isTemplate ? this.form.number_of_codes : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as IntegerFieldElement;\n this.edit({ number_of_codes: parseInt(field.value) });\n }}\n >\n </vaadin-integer-field>\n\n ${this.renderTemplateOrSlot('number-of-codes:after')}\n `;\n }\n\n private __renderPrefix() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('prefix:before')}\n\n <vaadin-text-field\n helper-text=${this.t('leave_empty_for_random_codes')}\n label=${this.t('prefix')}\n class=\"col-span-2\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('prefix', true)}\n ?readonly=${this.readonlySelector.matches('prefix', true)}\n clear-button-visible\n .value=${isTemplate ? this.form.prefix : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as TextFieldElement;\n this.edit({ prefix: field.value });\n }}\n >\n </vaadin-text-field>\n\n ${this.renderTemplateOrSlot('prefix:after')}\n `;\n }\n\n private __renderGenerate() {\n const isValidTemplate = this.in({ idle: { template: { dirty: 'valid' } } });\n\n return html`\n ${this.renderTemplateOrSlot('generate:before')}\n\n <vaadin-button\n class=\"col-span-2\"\n theme=\"success primary\"\n ?disabled=${!isValidTemplate || this.disabledSelector.matches('generate', true)}\n @click=${this.submit}\n >\n <foxy-i18n lang=${this.lang} key=\"generate\" ns=${this.ns}></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('create:after')}\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"GenerateCodesForm.js","sourceRoot":"","sources":["../../../../src/elements/public/GenerateCodesForm/GenerateCodesForm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Data, Templates } from './types';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { IntegerFieldElement } from '@vaadin/vaadin-text-field/vaadin-integer-field';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { NucleonV8N } from '../NucleonElement/types';\nimport { TextFieldElement } from '@vaadin/vaadin-text-field/vaadin-text-field';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\n\nconst NS = 'generate-codes';\nconst Base = ConfigurableMixin(ThemeableMixin(TranslatableMixin(NucleonElement, NS)));\n\n/**\n * Form element for generating codes for coupons or gift cards (`fx:generate_codes`).\n *\n * @slot length:before\n * @slot length:after\n *\n * @slot number-of-codes:before\n * @slot number-of-codes:after\n *\n * @slot prefix:before\n * @slot prefix:after\n *\n * @slot current-balance:before\n * @slot current-balance:after\n *\n * @slot generate:before\n * @slot generate:after\n *\n * @element foxy-generate-codes-form\n * @since 1.15.0\n */\nexport class GenerateCodesForm extends Base<Data> {\n static get v8n(): NucleonV8N<Data> {\n return [\n ({ number_of_codes: v }) => (v && v > 0) || 'number_of_codes_required',\n ({ current_balance: v }) => !v || v >= 0 || 'current_balance_negative',\n ({ length: v }) => (v && v > 0) || 'length_required',\n ];\n }\n\n templates: Templates = {};\n\n render(): TemplateResult {\n const { hiddenSelector, lang, ns } = this;\n\n const isBusy = this.in('busy');\n const isFail = this.in('fail');\n const isSnapshot = this.in({ idle: 'snapshot' });\n const isTemplate = this.in({ idle: 'template' });\n\n const transition = 'transition-opacity duration-500';\n const hidden = 'opacity-0 pointer-events-none';\n\n return html`\n <div aria-busy=${isBusy} aria-live=\"polite\" class=\"relative\">\n <div\n class=${classMap({\n 'grid grid-cols-2 gap-m': true,\n [transition]: true,\n [hidden]: isSnapshot,\n })}\n >\n ${hiddenSelector.matches('length', true) ? '' : this.__renderLength()}\n ${hiddenSelector.matches('number-of-codes', true) ? '' : this.__renderNumberOfCodes()}\n ${hiddenSelector.matches('current-balance', true) ? '' : this.__renderCurrentBalance()}\n ${hiddenSelector.matches('prefix', true) ? '' : this.__renderPrefix()}\n ${hiddenSelector.matches('generate', true) ? '' : this.__renderGenerate()}\n </div>\n\n <div\n class=${classMap({\n 'absolute inset-0 flex flex-col items-center justify-center': true,\n 'text-center text-m text-secondary leading-m': true,\n [transition]: true,\n [hidden]: !isSnapshot,\n })}\n >\n <div class=\"mx-auto flex mb-m w-l h-l rounded-t-l rounded-b-l bg-success\">\n <iron-icon icon=\"icons:done-all\" class=\"m-auto text-success-contrast\"></iron-icon>\n </div>\n\n <foxy-i18n class=\"block\" lang=${lang} key=\"generate_codes_done\" ns=${ns}></foxy-i18n>\n </div>\n\n <div\n class=${classMap({\n 'absolute inset-0 flex': true,\n [transition]: true,\n [hidden]: !isBusy && !isFail,\n })}\n >\n <foxy-spinner\n layout=\"vertical\"\n class=\"m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l\"\n state=${isFail ? 'error' : isTemplate ? 'empty' : 'busy'}\n lang=${lang}\n ns=\"${ns} ${customElements.get('foxy-spinner')?.defaultNS ?? ''}\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n\n private __getErrorMessage(prefix: string) {\n const error = this.errors.find(err => err.startsWith(prefix));\n return error ? this.t(error.replace(prefix, 'v8n')) : '';\n }\n\n private __getValidator(prefix: string) {\n return () => !this.errors.some(err => err.startsWith(prefix));\n }\n\n private __renderLength() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('length:before')}\n\n <vaadin-integer-field\n error-message=${this.__getErrorMessage('length')}\n label=${this.t('length')}\n class=\"w-full\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('length', true)}\n ?readonly=${this.readonlySelector.matches('length', true)}\n prevent-invalid-input\n has-controls\n .checkValidity=${this.__getValidator('length')}\n .value=${isTemplate ? this.form.length : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as IntegerFieldElement;\n this.edit({ length: parseInt(field.value) });\n }}\n >\n </vaadin-integer-field>\n\n ${this.renderTemplateOrSlot('length:after')}\n `;\n }\n\n private __renderNumberOfCodes() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('number-of-codes:before')}\n\n <vaadin-integer-field\n error-message=${this.__getErrorMessage('number_of_codes')}\n label=${this.t('number_of_codes')}\n class=\"w-full\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('number-of-codes', true)}\n ?readonly=${this.readonlySelector.matches('number-of-codes', true)}\n prevent-invalid-input\n has-controls\n .checkValidity=${this.__getValidator('number_of_codes')}\n .value=${isTemplate ? this.form.number_of_codes : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as IntegerFieldElement;\n this.edit({ number_of_codes: parseInt(field.value) });\n }}\n >\n </vaadin-integer-field>\n\n ${this.renderTemplateOrSlot('number-of-codes:after')}\n `;\n }\n\n private __renderCurrentBalance() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('current-balance:before')}\n\n <vaadin-integer-field\n error-message=${this.__getErrorMessage('current_balance')}\n label=${this.t('balance')}\n class=\"w-full col-span-2\"\n min=\"0\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('current-balance', true)}\n ?readonly=${this.readonlySelector.matches('current-balance', true)}\n prevent-invalid-input\n has-controls\n .checkValidity=${this.__getValidator('current_balance')}\n .value=${isTemplate ? this.form.current_balance ?? 0 : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as IntegerFieldElement;\n this.edit({ current_balance: parseInt(field.value) });\n }}\n >\n </vaadin-integer-field>\n\n ${this.renderTemplateOrSlot('current-balance:after')}\n `;\n }\n\n private __renderPrefix() {\n const isTemplate = this.in({ idle: 'template' });\n\n return html`\n ${this.renderTemplateOrSlot('prefix:before')}\n\n <vaadin-text-field\n helper-text=${this.t('leave_empty_for_random_codes')}\n label=${this.t('prefix')}\n class=\"col-span-2\"\n min=\"1\"\n ?disabled=${!isTemplate || this.disabledSelector.matches('prefix', true)}\n ?readonly=${this.readonlySelector.matches('prefix', true)}\n clear-button-visible\n .value=${isTemplate ? this.form.prefix : ''}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as TextFieldElement;\n this.edit({ prefix: field.value });\n }}\n >\n </vaadin-text-field>\n\n ${this.renderTemplateOrSlot('prefix:after')}\n `;\n }\n\n private __renderGenerate() {\n const isValidTemplate = this.in({ idle: { template: { dirty: 'valid' } } });\n\n return html`\n ${this.renderTemplateOrSlot('generate:before')}\n\n <vaadin-button\n class=\"col-span-2\"\n theme=\"success primary\"\n ?disabled=${!isValidTemplate || this.disabledSelector.matches('generate', true)}\n @click=${this.submit}\n >\n <foxy-i18n lang=${this.lang} key=\"generate\" ns=${this.ns}></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('create:after')}\n `;\n }\n}\n"]}
@@ -0,0 +1,26 @@
1
+ import { Data, Templates } from './types';
2
+ import { TemplateResult } from 'lit-html';
3
+ import { NucleonElement } from '../NucleonElement/NucleonElement';
4
+ declare const Base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
5
+ defaultNS: string;
6
+ } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost> & {
7
+ styles: import("lit-element").CSSResultArray;
8
+ };
9
+ /**
10
+ * Basic card displaying a gift card.
11
+ *
12
+ * @slot title:before
13
+ * @slot title:after
14
+ * @slot status:before
15
+ * @slot status:after
16
+ *
17
+ * @element foxy-gift-card-card
18
+ * @since 1.15.0
19
+ */
20
+ export declare class GiftCardCard extends Base<Data> {
21
+ templates: Templates;
22
+ render(): TemplateResult;
23
+ private __renderTitle;
24
+ private __renderStatus;
25
+ }
26
+ export {};
@@ -0,0 +1,95 @@
1
+ import { html } from 'lit-html';
2
+ import { ConfigurableMixin } from "../../../mixins/configurable.js";
3
+ import { NucleonElement } from "../NucleonElement/NucleonElement.js";
4
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
5
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
6
+ import { classMap } from "../../../utils/class-map.js";
7
+ const NS = 'gift-card-card';
8
+ const Base = ThemeableMixin(ConfigurableMixin(TranslatableMixin(NucleonElement, NS)));
9
+ /**
10
+ * Basic card displaying a gift card.
11
+ *
12
+ * @slot title:before
13
+ * @slot title:after
14
+ * @slot status:before
15
+ * @slot status:after
16
+ *
17
+ * @element foxy-gift-card-card
18
+ * @since 1.15.0
19
+ */
20
+ export class GiftCardCard extends Base {
21
+ constructor() {
22
+ super(...arguments);
23
+ this.templates = {};
24
+ }
25
+ render() {
26
+ var _a, _b;
27
+ const hiddenSelector = this.hiddenSelector;
28
+ return html `
29
+ <div
30
+ aria-busy=${this.in('busy')}
31
+ aria-live="polite"
32
+ class="relative leading-m font-lumo text-m"
33
+ >
34
+ <div class=${classMap({ 'transition-opacity': true, 'opacity-0': !this.data })}>
35
+ ${hiddenSelector.matches('title', true) ? '' : this.__renderTitle()}
36
+ ${hiddenSelector.matches('status', true) ? '' : this.__renderStatus()}
37
+ </div>
38
+
39
+ <div
40
+ class=${classMap({
41
+ 'pointer-events-none absolute inset-0 flex transition-opacity': true,
42
+ 'opacity-0': !!this.data,
43
+ })}
44
+ >
45
+ <foxy-spinner
46
+ data-testid="spinner"
47
+ state=${this.in('fail') ? 'error' : this.in({ idle: 'template' }) ? 'empty' : 'busy'}
48
+ class="m-auto"
49
+ lang=${this.lang}
50
+ ns="${this.ns} ${(_b = (_a = customElements.get('foxy-spinner')) === null || _a === void 0 ? void 0 : _a.defaultNS) !== null && _b !== void 0 ? _b : ''}"
51
+ >
52
+ </foxy-spinner>
53
+ </div>
54
+ </div>
55
+ `;
56
+ }
57
+ __renderTitle() {
58
+ var _a, _b, _c, _d;
59
+ const name = (_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : html `&ZeroWidthSpace;`;
60
+ const code = (_d = (_c = this.data) === null || _c === void 0 ? void 0 : _c.currency_code) !== null && _d !== void 0 ? _d : html `&ZeroWidthSpace;`;
61
+ return html `
62
+ <div data-testid="title">
63
+ ${this.renderTemplateOrSlot('title:before')}
64
+
65
+ <div class="flex items-center justify-between">
66
+ <div class="font-semibold truncate">${name}</div>
67
+ <div class="text-tertiary uppercase text-s flex-shrink-0">${code}</div>
68
+ </div>
69
+
70
+ ${this.renderTemplateOrSlot('title:after')}
71
+ </div>
72
+ `;
73
+ }
74
+ __renderStatus() {
75
+ var _a;
76
+ const expiresAfter = (_a = this.data) === null || _a === void 0 ? void 0 : _a.expires_after;
77
+ return html `
78
+ <div data-testid="status">
79
+ ${this.renderTemplateOrSlot('status:before')}
80
+
81
+ <foxy-i18n
82
+ options=${JSON.stringify({ value: expiresAfter })}
83
+ class="block truncate text-s text-tertiary"
84
+ lang=${this.lang}
85
+ key=${expiresAfter ? 'expires_after_value' : 'never_expires'}
86
+ ns=${this.ns}
87
+ >
88
+ </foxy-i18n>
89
+
90
+ ${this.renderTemplateOrSlot('status:after')}
91
+ </div>
92
+ `;
93
+ }
94
+ }
95
+ //# sourceMappingURL=GiftCardCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"GiftCardCard.js","sourceRoot":"","sources":["../../../../src/elements/public/GiftCardCard/GiftCardCard.ts"],"names":[],"mappings":"AACA,OAAO,EAAkB,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhD,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,cAAc,EAAE,4CAAyC;AAClE,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AAEpD,MAAM,EAAE,GAAG,gBAAgB,CAAC;AAC5B,MAAM,IAAI,GAAG,cAAc,CAAC,iBAAiB,CAAC,iBAAiB,CAAC,cAAc,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;AAEtF;;;;;;;;;;GAUG;AACH,MAAM,OAAO,YAAa,SAAQ,IAAU;IAA5C;;QACE,cAAS,GAAc,EAAE,CAAC;IAyE5B,CAAC;IAvEC,MAAM;;QACJ,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC;QAE3C,OAAO,IAAI,CAAA;;oBAEK,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC;;;;qBAId,QAAQ,CAAC,EAAE,oBAAoB,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YAC1E,cAAc,CAAC,OAAO,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE;YACjE,cAAc,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,EAAE;;;;kBAI7D,QAAQ,CAAC;YACf,8DAA8D,EAAE,IAAI;YACpE,WAAW,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI;SACzB,CAAC;;;;oBAIQ,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;;mBAE7E,IAAI,CAAC,IAAI;kBACV,IAAI,CAAC,EAAE,IAAI,YAAA,cAAc,CAAC,GAAG,CAAC,cAAc,CAAC,0CAAE,SAAS,mCAAI,EAAE;;;;;KAK3E,CAAC;IACJ,CAAC;IAEO,aAAa;;QACnB,MAAM,IAAI,eAAG,IAAI,CAAC,IAAI,0CAAE,IAAI,mCAAI,IAAI,CAAA,kBAAkB,CAAC;QACvD,MAAM,IAAI,eAAG,IAAI,CAAC,IAAI,0CAAE,aAAa,mCAAI,IAAI,CAAA,kBAAkB,CAAC;QAEhE,OAAO,IAAI,CAAA;;UAEL,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC;;;gDAGH,IAAI;sEACkB,IAAI;;;UAGhE,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC;;KAE7C,CAAC;IACJ,CAAC;IAEO,cAAc;;QACpB,MAAM,YAAY,SAAG,IAAI,CAAC,IAAI,0CAAE,aAAa,CAAC;QAE9C,OAAO,IAAI,CAAA;;UAEL,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC;;;oBAGhC,IAAI,CAAC,SAAS,CAAC,EAAE,KAAK,EAAE,YAAY,EAAE,CAAC;;iBAE1C,IAAI,CAAC,IAAI;gBACV,YAAY,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,eAAe;eACvD,IAAI,CAAC,EAAE;;;;UAIZ,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC;;KAE9C,CAAC;IACJ,CAAC;CACF","sourcesContent":["import { Data, Templates } from './types';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\n\nconst NS = 'gift-card-card';\nconst Base = ThemeableMixin(ConfigurableMixin(TranslatableMixin(NucleonElement, NS)));\n\n/**\n * Basic card displaying a gift card.\n *\n * @slot title:before\n * @slot title:after\n * @slot status:before\n * @slot status:after\n *\n * @element foxy-gift-card-card\n * @since 1.15.0\n */\nexport class GiftCardCard extends Base<Data> {\n templates: Templates = {};\n\n render(): TemplateResult {\n const hiddenSelector = this.hiddenSelector;\n\n return html`\n <div\n aria-busy=${this.in('busy')}\n aria-live=\"polite\"\n class=\"relative leading-m font-lumo text-m\"\n >\n <div class=${classMap({ 'transition-opacity': true, 'opacity-0': !this.data })}>\n ${hiddenSelector.matches('title', true) ? '' : this.__renderTitle()}\n ${hiddenSelector.matches('status', true) ? '' : this.__renderStatus()}\n </div>\n\n <div\n class=${classMap({\n 'pointer-events-none absolute inset-0 flex transition-opacity': true,\n 'opacity-0': !!this.data,\n })}\n >\n <foxy-spinner\n data-testid=\"spinner\"\n state=${this.in('fail') ? 'error' : this.in({ idle: 'template' }) ? 'empty' : 'busy'}\n class=\"m-auto\"\n lang=${this.lang}\n ns=\"${this.ns} ${customElements.get('foxy-spinner')?.defaultNS ?? ''}\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n\n private __renderTitle() {\n const name = this.data?.name ?? html`&ZeroWidthSpace;`;\n const code = this.data?.currency_code ?? html`&ZeroWidthSpace;`;\n\n return html`\n <div data-testid=\"title\">\n ${this.renderTemplateOrSlot('title:before')}\n\n <div class=\"flex items-center justify-between\">\n <div class=\"font-semibold truncate\">${name}</div>\n <div class=\"text-tertiary uppercase text-s flex-shrink-0\">${code}</div>\n </div>\n\n ${this.renderTemplateOrSlot('title:after')}\n </div>\n `;\n }\n\n private __renderStatus() {\n const expiresAfter = this.data?.expires_after;\n\n return html`\n <div data-testid=\"status\">\n ${this.renderTemplateOrSlot('status:before')}\n\n <foxy-i18n\n options=${JSON.stringify({ value: expiresAfter })}\n class=\"block truncate text-s text-tertiary\"\n lang=${this.lang}\n key=${expiresAfter ? 'expires_after_value' : 'never_expires'}\n ns=${this.ns}\n >\n </foxy-i18n>\n\n ${this.renderTemplateOrSlot('status:after')}\n </div>\n `;\n }\n}\n"]}
@@ -0,0 +1,5 @@
1
+ import '../../internal/InternalSandbox/index';
2
+ import '../Spinner/index';
3
+ import '../I18n/index';
4
+ import { GiftCardCard } from './GiftCardCard';
5
+ export { GiftCardCard };
@@ -0,0 +1,7 @@
1
+ import "../../internal/InternalSandbox/index.js";
2
+ import "../Spinner/index.js";
3
+ import "../I18n/index.js";
4
+ import { GiftCardCard } from "./GiftCardCard.js";
5
+ customElements.define('foxy-gift-card-card', GiftCardCard);
6
+ export { GiftCardCard };
7
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/public/GiftCardCard/index.ts"],"names":[],"mappings":"AAAA,iDAA8C;AAC9C,6BAA0B;AAC1B,0BAAuB;AAEvB,OAAO,EAAE,YAAY,EAAE,0BAAuB;AAE9C,cAAc,CAAC,MAAM,CAAC,qBAAqB,EAAE,YAAY,CAAC,CAAC;AAE3D,OAAO,EAAE,YAAY,EAAE,CAAC","sourcesContent":["import '../../internal/InternalSandbox/index';\nimport '../Spinner/index';\nimport '../I18n/index';\n\nimport { GiftCardCard } from './GiftCardCard';\n\ncustomElements.define('foxy-gift-card-card', GiftCardCard);\n\nexport { GiftCardCard };\n"]}
@@ -0,0 +1,11 @@
1
+ import { GiftCardCard } from './GiftCardCard';
2
+ import { Rels } from '@foxy.io/sdk/backend';
3
+ import { Renderer } from '../../../mixins/configurable';
4
+ import { Resource } from '@foxy.io/sdk/core';
5
+ export declare type Data = Resource<Rels.GiftCard>;
6
+ export declare type Templates = Partial<{
7
+ 'title:before': Renderer<GiftCardCard>;
8
+ 'title:after': Renderer<GiftCardCard>;
9
+ 'status:before': Renderer<GiftCardCard>;
10
+ 'status:after': Renderer<GiftCardCard>;
11
+ }>;
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/elements/public/GiftCardCard/types.ts"],"names":[],"mappings":"","sourcesContent":["import { GiftCardCard } from './GiftCardCard';\nimport { Rels } from '@foxy.io/sdk/backend';\nimport { Renderer } from '../../../mixins/configurable';\nimport { Resource } from '@foxy.io/sdk/core';\n\nexport type Data = Resource<Rels.GiftCard>;\n\nexport type Templates = Partial<{\n 'title:before': Renderer<GiftCardCard>;\n 'title:after': Renderer<GiftCardCard>;\n 'status:before': Renderer<GiftCardCard>;\n 'status:after': Renderer<GiftCardCard>;\n}>;\n"]}
@@ -0,0 +1,55 @@
1
+ import { Data, Templates } from './types';
2
+ import { ScopedElementsMap } from '@open-wc/scoped-elements';
3
+ import { TemplateResult } from 'lit-html';
4
+ import { NucleonElement } from '../NucleonElement/NucleonElement';
5
+ import { NucleonV8N } from '../NucleonElement/types';
6
+ declare const Base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
7
+ defaultNS: string;
8
+ } & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/src/types").ScopedElementsHost> & {
9
+ styles: import("lit-element").CSSResultArray;
10
+ } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost>;
11
+ /**
12
+ * Form element for creating or editing gift card codes (`fx:gift_card_code`).
13
+ *
14
+ * @slot code:before
15
+ * @slot code:after
16
+ *
17
+ * @slot current-balance:before
18
+ * @slot current-balance:after
19
+ *
20
+ * @slot end-date:before
21
+ * @slot end-date:after
22
+ *
23
+ * @slot timestamps:before
24
+ * @slot timestamps:after
25
+ *
26
+ * @slot delete:before
27
+ * @slot delete:after
28
+ *
29
+ * @slot create:before
30
+ * @slot create:after
31
+ *
32
+ * @element foxy-gift-card-code-form
33
+ * @since 1.15.0
34
+ */
35
+ export declare class GiftCardCodeForm extends Base<Data> {
36
+ static get scopedElements(): ScopedElementsMap;
37
+ static get v8n(): NucleonV8N<Data>;
38
+ templates: Templates;
39
+ render(): TemplateResult;
40
+ private get __isCodeHidden();
41
+ private get __isCurrentBalanceHidden();
42
+ private get __isEndDateHidden();
43
+ private get __isTimestampsHidden();
44
+ private get __isCreateHidden();
45
+ private get __isDeleteHidden();
46
+ private __getErrorMessage;
47
+ private __getValidator;
48
+ private __renderCode;
49
+ private __renderCurrentBalance;
50
+ private __renderEndDate;
51
+ private __renderTimestamps;
52
+ private __renderCreate;
53
+ private __renderDelete;
54
+ }
55
+ export {};
@@ -0,0 +1,292 @@
1
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
2
+ import { html } from 'lit-html';
3
+ import { ConfigurableMixin } from "../../../mixins/configurable.js";
4
+ import { NucleonElement } from "../NucleonElement/NucleonElement.js";
5
+ import { PropertyTable } from "../../private/index.js";
6
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
7
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
8
+ import { classMap } from "../../../utils/class-map.js";
9
+ const NS = 'gift-card-code-form';
10
+ const Base = ConfigurableMixin(ThemeableMixin(ScopedElementsMixin(TranslatableMixin(NucleonElement, NS))));
11
+ /**
12
+ * Form element for creating or editing gift card codes (`fx:gift_card_code`).
13
+ *
14
+ * @slot code:before
15
+ * @slot code:after
16
+ *
17
+ * @slot current-balance:before
18
+ * @slot current-balance:after
19
+ *
20
+ * @slot end-date:before
21
+ * @slot end-date:after
22
+ *
23
+ * @slot timestamps:before
24
+ * @slot timestamps:after
25
+ *
26
+ * @slot delete:before
27
+ * @slot delete:after
28
+ *
29
+ * @slot create:before
30
+ * @slot create:after
31
+ *
32
+ * @element foxy-gift-card-code-form
33
+ * @since 1.15.0
34
+ */
35
+ export class GiftCardCodeForm extends Base {
36
+ constructor() {
37
+ super(...arguments);
38
+ this.templates = {};
39
+ }
40
+ static get scopedElements() {
41
+ return {
42
+ 'vaadin-number-field': customElements.get('vaadin-number-field'),
43
+ 'vaadin-date-picker': customElements.get('vaadin-date-picker'),
44
+ 'vaadin-text-field': customElements.get('vaadin-text-field'),
45
+ 'vaadin-button': customElements.get('vaadin-button'),
46
+ 'foxy-internal-confirm-dialog': customElements.get('foxy-internal-confirm-dialog'),
47
+ 'foxy-internal-sandbox': customElements.get('foxy-internal-sandbox'),
48
+ 'foxy-spinner': customElements.get('foxy-spinner'),
49
+ 'foxy-i18n': customElements.get('foxy-i18n'),
50
+ 'x-property-table': PropertyTable,
51
+ };
52
+ }
53
+ static get v8n() {
54
+ return [
55
+ ({ code: v }) => !!v || 'code_required',
56
+ ({ code: v }) => !v || v.length <= 50 || 'code_too_long',
57
+ ({ current_balance: v }) => !!v || 'current_balance_required',
58
+ ({ current_balance: v }) => !v || !isNaN(v) || 'current_balance_required',
59
+ ];
60
+ }
61
+ render() {
62
+ var _a, _b;
63
+ return html `
64
+ <div class="relative space-y-m">
65
+ ${this.__isCodeHidden ? null : this.__renderCode()}
66
+ ${this.__isCurrentBalanceHidden ? null : this.__renderCurrentBalance()}
67
+ ${this.__isEndDateHidden ? null : this.__renderEndDate()}
68
+ ${this.__isTimestampsHidden ? null : this.__renderTimestamps()}
69
+ ${this.__isCreateHidden ? null : this.__renderCreate()}
70
+ ${this.__isDeleteHidden ? null : this.__renderDelete()}
71
+
72
+ <div
73
+ data-testid="spinner"
74
+ class=${classMap({
75
+ 'transition duration-500 ease-in-out absolute inset-0 flex': true,
76
+ 'opacity-0 pointer-events-none': !this.in('busy') && !this.in('fail'),
77
+ })}
78
+ >
79
+ <foxy-spinner
80
+ layout="vertical"
81
+ class="m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l"
82
+ state=${this.in('fail') ? 'error' : this.in('busy') ? 'busy' : 'empty'}
83
+ lang=${this.lang}
84
+ ns="${this.ns} ${(_b = (_a = customElements.get('foxy-spinner')) === null || _a === void 0 ? void 0 : _a.defaultNS) !== null && _b !== void 0 ? _b : ''}"
85
+ >
86
+ </foxy-spinner>
87
+ </div>
88
+ </div>
89
+ `;
90
+ }
91
+ get __isCodeHidden() {
92
+ return this.hiddenSelector.matches('code', true);
93
+ }
94
+ get __isCurrentBalanceHidden() {
95
+ return this.hiddenSelector.matches('current-balance', true);
96
+ }
97
+ get __isEndDateHidden() {
98
+ return this.hiddenSelector.matches('end-date', true);
99
+ }
100
+ get __isTimestampsHidden() {
101
+ if (this.hiddenSelector.matches('timestamps', true))
102
+ return true;
103
+ return !this.data;
104
+ }
105
+ get __isCreateHidden() {
106
+ if (this.hiddenSelector.matches('create', true))
107
+ return true;
108
+ return !!this.data;
109
+ }
110
+ get __isDeleteHidden() {
111
+ if (this.hiddenSelector.matches('delete', true))
112
+ return true;
113
+ return !this.data;
114
+ }
115
+ __getErrorMessage(prefix) {
116
+ const error = this.errors.find(err => err.startsWith(prefix));
117
+ return error ? this.t(error.replace(prefix, 'v8n')).toString() : '';
118
+ }
119
+ __getValidator(prefix) {
120
+ return () => !this.errors.some(err => err.startsWith(prefix));
121
+ }
122
+ __renderCode() {
123
+ return html `
124
+ <div>
125
+ ${this.renderTemplateOrSlot('code:before')}
126
+
127
+ <vaadin-text-field
128
+ data-testid="code"
129
+ class="w-full"
130
+ label=${this.t('code')}
131
+ .checkValidity=${this.__getValidator('code')}
132
+ .errorMessage=${this.__getErrorMessage('code')}
133
+ .value=${this.form.code}
134
+ ?disabled=${this.in('busy') || this.disabledSelector.matches('code', true)}
135
+ ?readonly=${this.readonlySelector.matches('code', true)}
136
+ required
137
+ @keydown=${(evt) => evt.key === 'Enter' && this.submit()}
138
+ @input=${(evt) => {
139
+ const newCode = evt.currentTarget.value;
140
+ this.edit({ code: newCode });
141
+ }}
142
+ >
143
+ </vaadin-text-field>
144
+
145
+ ${this.renderTemplateOrSlot('code:after')}
146
+ </div>
147
+ `;
148
+ }
149
+ __renderCurrentBalance() {
150
+ return html `
151
+ <div>
152
+ ${this.renderTemplateOrSlot('current-balance:before')}
153
+
154
+ <vaadin-number-field
155
+ data-testid="current-balance"
156
+ class="w-full"
157
+ label=${this.t('current_balance')}
158
+ min="0"
159
+ .checkValidity=${this.__getValidator('current_balance')}
160
+ .errorMessage=${this.__getErrorMessage('current_balance')}
161
+ .value=${this.form.current_balance}
162
+ ?disabled=${this.in('busy') || this.disabledSelector.matches('current-balance', true)}
163
+ ?readonly=${this.readonlySelector.matches('current-balance', true)}
164
+ prevent-invalid-input
165
+ has-controls
166
+ required
167
+ @keydown=${(evt) => evt.key === 'Enter' && this.submit()}
168
+ @change=${(evt) => {
169
+ const newCurrentBalance = evt.currentTarget.value;
170
+ this.edit({ current_balance: parseFloat(newCurrentBalance) });
171
+ }}
172
+ >
173
+ </vaadin-number-field>
174
+
175
+ ${this.renderTemplateOrSlot('current-balance:after')}
176
+ </div>
177
+ `;
178
+ }
179
+ __renderEndDate() {
180
+ return html `
181
+ <div>
182
+ ${this.renderTemplateOrSlot('end-date:before')}
183
+
184
+ <vaadin-date-picker
185
+ data-testid="end-date"
186
+ class="w-full"
187
+ label=${this.t('end_date')}
188
+ min="0"
189
+ .checkValidity=${this.__getValidator('end_date')}
190
+ .errorMessage=${this.__getErrorMessage('end_date')}
191
+ .value=${this.form.end_date}
192
+ ?disabled=${this.in('busy') || this.disabledSelector.matches('end-date', true)}
193
+ ?readonly=${this.readonlySelector.matches('end-date', true)}
194
+ @keydown=${(evt) => evt.key === 'Enter' && this.submit()}
195
+ @change=${(evt) => {
196
+ const newEndDate = evt.currentTarget.value;
197
+ this.edit({ end_date: newEndDate });
198
+ }}
199
+ >
200
+ </vaadin-date-picker>
201
+
202
+ ${this.renderTemplateOrSlot('end-date:after')}
203
+ </div>
204
+ `;
205
+ }
206
+ __renderTimestamps() {
207
+ return html `
208
+ <div>
209
+ ${this.renderTemplateOrSlot('timestamps:before')}
210
+
211
+ <x-property-table
212
+ data-testid="timestamps"
213
+ .items=${['date_modified', 'date_created'].map(field => {
214
+ var _a;
215
+ return ({
216
+ name: this.t(field),
217
+ value: ((_a = this.data) === null || _a === void 0 ? void 0 : _a[field]) ? this.t('date', { value: new Date(this.data[field]) })
218
+ : '',
219
+ });
220
+ })}
221
+ >
222
+ </x-property-table>
223
+
224
+ ${this.renderTemplateOrSlot('timestamps:after')}
225
+ </div>
226
+ `;
227
+ }
228
+ __renderCreate() {
229
+ const isCleanTemplateInvalid = this.in({ idle: { template: { clean: 'invalid' } } });
230
+ const isDirtyTemplateInvalid = this.in({ idle: { template: { dirty: 'invalid' } } });
231
+ const isCleanSnapshotInvalid = this.in({ idle: { snapshot: { clean: 'invalid' } } });
232
+ const isDirtySnapshotInvalid = this.in({ idle: { snapshot: { dirty: 'invalid' } } });
233
+ const isTemplateInvalid = isCleanTemplateInvalid || isDirtyTemplateInvalid;
234
+ const isSnaphotInvalid = isCleanSnapshotInvalid || isDirtySnapshotInvalid;
235
+ const isInvalid = isTemplateInvalid || isSnaphotInvalid;
236
+ const isBusy = this.in('busy');
237
+ return html `
238
+ <div>
239
+ ${this.renderTemplateOrSlot('create:before')}
240
+
241
+ <vaadin-button
242
+ data-testid="create"
243
+ class="w-full"
244
+ theme="primary success"
245
+ ?disabled=${isBusy || isInvalid || this.disabledSelector.matches('create', true)}
246
+ @click=${this.submit}
247
+ >
248
+ <foxy-i18n ns=${this.ns} key="create" lang=${this.lang}></foxy-i18n>
249
+ </vaadin-button>
250
+
251
+ ${this.renderTemplateOrSlot('create:after')}
252
+ </div>
253
+ `;
254
+ }
255
+ __renderDelete() {
256
+ return html `
257
+ <div>
258
+ <foxy-internal-confirm-dialog
259
+ data-testid="confirm"
260
+ message="delete_prompt"
261
+ confirm="delete"
262
+ cancel="cancel"
263
+ header="delete"
264
+ theme="primary error"
265
+ lang=${this.lang}
266
+ ns=${this.ns}
267
+ id="confirm"
268
+ @hide=${(evt) => !evt.detail.cancelled && this.delete()}
269
+ >
270
+ </foxy-internal-confirm-dialog>
271
+
272
+ ${this.renderTemplateOrSlot('delete:before')}
273
+
274
+ <vaadin-button
275
+ data-testid="delete"
276
+ theme="primary error"
277
+ class="w-full"
278
+ ?disabled=${this.in('busy') || this.disabledSelector.matches('delete', true)}
279
+ @click=${(evt) => {
280
+ const confirm = this.renderRoot.querySelector('#confirm');
281
+ confirm.show(evt.currentTarget);
282
+ }}
283
+ >
284
+ <foxy-i18n ns=${this.ns} key="delete" lang=${this.lang}></foxy-i18n>
285
+ </vaadin-button>
286
+
287
+ ${this.renderTemplateOrSlot('delete:after')}
288
+ </div>
289
+ `;
290
+ }
291
+ }
292
+ //# sourceMappingURL=GiftCardCodeForm.js.map