@foxy.io/elements 1.14.0-beta.1 → 1.14.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 (164) hide show
  1. package/README.md +1 -1
  2. package/dist/cdn/foxy-access-recovery-form.js +1 -1
  3. package/dist/cdn/foxy-address-card.js +1 -1
  4. package/dist/cdn/foxy-address-form.js +1 -1
  5. package/dist/cdn/foxy-applied-tax-card.js +1 -1
  6. package/dist/cdn/foxy-attribute-card.js +1 -1
  7. package/dist/cdn/foxy-attribute-form.js +1 -1
  8. package/dist/cdn/foxy-cancellation-form.js +1 -1
  9. package/dist/cdn/foxy-collection-page.js +1 -1
  10. package/dist/cdn/foxy-collection-pages.js +1 -1
  11. package/dist/cdn/foxy-custom-field-card.js +1 -1
  12. package/dist/cdn/foxy-custom-field-form.js +1 -1
  13. package/dist/cdn/foxy-customer-api.js +1 -1
  14. package/dist/cdn/foxy-customer-card.js +1 -1
  15. package/dist/cdn/foxy-customer-form.js +1 -1
  16. package/dist/cdn/foxy-customer-portal-settings.js +18 -18
  17. package/dist/cdn/foxy-customer-portal.js +1 -1
  18. package/dist/cdn/foxy-customer.js +4 -4
  19. package/dist/cdn/foxy-customers-table.js +1 -1
  20. package/dist/cdn/foxy-discount-card.js +1 -1
  21. package/dist/cdn/foxy-donation.js +1 -1
  22. package/dist/cdn/foxy-email-template-form.js +1 -0
  23. package/dist/cdn/foxy-error-entry-card.js +1 -1
  24. package/dist/cdn/foxy-form-dialog.js +1 -1
  25. package/dist/cdn/foxy-i18n.js +1 -1
  26. package/dist/cdn/foxy-items-form.js +1 -1
  27. package/dist/cdn/foxy-nucleon-element.js +1 -1
  28. package/dist/cdn/foxy-payment-card.js +1 -1
  29. package/dist/cdn/foxy-payment-method-card.js +1 -1
  30. package/dist/cdn/foxy-query-builder.js +1 -1
  31. package/dist/cdn/foxy-sign-in-form.js +1 -1
  32. package/dist/cdn/foxy-spinner.js +2 -2
  33. package/dist/cdn/foxy-subscription-card.js +1 -1
  34. package/dist/cdn/foxy-subscription-form.js +26 -9
  35. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  36. package/dist/cdn/foxy-table.js +1 -1
  37. package/dist/cdn/foxy-tax-card.js +1 -1
  38. package/dist/cdn/foxy-tax-form.js +1 -1
  39. package/dist/cdn/foxy-template-config-form.js +1 -0
  40. package/dist/cdn/foxy-template-form.js +1 -1
  41. package/dist/cdn/foxy-transaction-card.js +1 -1
  42. package/dist/cdn/foxy-transactions-table.js +1 -1
  43. package/dist/cdn/foxy-user-form.js +1 -1
  44. package/dist/cdn/foxy-users-table.js +1 -1
  45. package/dist/cdn/{shared-151ca103.js → shared-00070cc4.js} +1 -1
  46. package/dist/cdn/{shared-d4dad105.js → shared-00563cb0.js} +1 -1
  47. package/dist/cdn/shared-007c4e34.js +1 -0
  48. package/dist/cdn/shared-07134f93.js +14 -0
  49. package/dist/cdn/shared-0ced76a0.js +358 -0
  50. package/dist/cdn/shared-0f9809ab.js +1 -0
  51. package/dist/cdn/{shared-f4119f12.js → shared-16f72e27.js} +1 -1
  52. package/dist/cdn/shared-1761daef.js +15 -0
  53. package/dist/cdn/{shared-5fedf5e4.js → shared-200f613b.js} +2 -2
  54. package/dist/cdn/{shared-4059f633.js → shared-218ba06e.js} +1 -1
  55. package/dist/cdn/shared-31d03530.js +264 -0
  56. package/dist/cdn/{shared-e9920617.js → shared-34b2c1e2.js} +1 -1
  57. package/dist/cdn/{shared-cf248335.js → shared-44cfc617.js} +1 -1
  58. package/dist/cdn/{shared-45d647e4.js → shared-46ee137f.js} +1 -1
  59. package/dist/cdn/shared-4ba926ca.js +1 -0
  60. package/dist/cdn/{shared-f0199313.js → shared-593f7e2c.js} +1 -1
  61. package/dist/cdn/shared-59e44f29.js +1 -0
  62. package/dist/cdn/{shared-35415106.js → shared-5d94bacb.js} +1 -1
  63. package/dist/cdn/{shared-cd700eac.js → shared-60126eee.js} +1 -1
  64. package/dist/cdn/{shared-17968c53.js → shared-63eaded9.js} +3 -3
  65. package/dist/cdn/shared-6b7602c7.js +1 -0
  66. package/dist/cdn/{shared-98ee7fad.js → shared-6d45a07b.js} +1 -1
  67. package/dist/cdn/{shared-99f45065.js → shared-7007dedb.js} +1 -1
  68. package/dist/cdn/{shared-84fa75d9.js → shared-9221e6b2.js} +1 -1
  69. package/dist/cdn/{shared-2860a3d3.js → shared-94b0ae99.js} +2 -2
  70. package/dist/cdn/shared-a3d2c48e.js +314 -0
  71. package/dist/cdn/shared-a46edf4b.js +1 -0
  72. package/dist/cdn/{shared-54702b33.js → shared-b0f0e8b5.js} +1 -1
  73. package/dist/cdn/{shared-f2a4fd27.js → shared-b24377bf.js} +1 -1
  74. package/dist/cdn/{shared-ed4ed7a5.js → shared-b710881a.js} +2 -2
  75. package/dist/cdn/{shared-3ae39e52.js → shared-bb824ab4.js} +3 -3
  76. package/dist/cdn/{shared-6783c996.js → shared-c5ae5d33.js} +1 -1
  77. package/dist/cdn/shared-ca7c3b9a.js +1 -0
  78. package/dist/cdn/shared-d01035c5.js +1 -0
  79. package/dist/cdn/{shared-dbbe03f9.js → shared-d05c93a5.js} +1 -1
  80. package/dist/cdn/{shared-5d286626.js → shared-da787055.js} +1 -1
  81. package/dist/cdn/{shared-566252ac.js → shared-daf6b763.js} +1 -1
  82. package/dist/cdn/shared-df573cea.js +12 -0
  83. package/dist/cdn/{shared-e5de8675.js → shared-e7f8ffe9.js} +1 -1
  84. package/dist/cdn/{shared-54c485d2.js → shared-ec861f31.js} +21 -21
  85. package/dist/cdn/{shared-e0248713.js → shared-f0a83bd6.js} +1 -1
  86. package/dist/cdn/shared-fe8a7aa2.js +1 -0
  87. package/dist/cdn/{shared-747b0842.js → shared-ff79f3f9.js} +1 -1
  88. package/dist/cdn/translations/shared/en.json +87 -3
  89. package/dist/elements/private/Checkbox/Checkbox.d.ts +3 -1
  90. package/dist/elements/private/Checkbox/Checkbox.js +45 -12
  91. package/dist/elements/private/Checkbox/Checkbox.js.map +1 -1
  92. package/dist/elements/private/Choice/Choice.js +10 -8
  93. package/dist/elements/private/Choice/Choice.js.map +1 -1
  94. package/dist/elements/private/Group/Group.js +1 -1
  95. package/dist/elements/private/Group/Group.js.map +1 -1
  96. package/dist/elements/private/I18N/I18N.js +1 -1
  97. package/dist/elements/private/I18N/I18N.js.map +1 -1
  98. package/dist/elements/public/AddressForm/AddressForm.js +8 -4
  99. package/dist/elements/public/AddressForm/AddressForm.js.map +1 -1
  100. package/dist/elements/public/AttributeForm/AttributeForm.js +8 -4
  101. package/dist/elements/public/AttributeForm/AttributeForm.js.map +1 -1
  102. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js +8 -4
  103. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js.map +1 -1
  104. package/dist/elements/public/CustomerForm/CustomerForm.js +8 -4
  105. package/dist/elements/public/CustomerForm/CustomerForm.js.map +1 -1
  106. package/dist/elements/public/EmailTemplateForm/EmailTemplateForm.d.ts +46 -0
  107. package/dist/elements/public/EmailTemplateForm/EmailTemplateForm.js +350 -0
  108. package/dist/elements/public/EmailTemplateForm/EmailTemplateForm.js.map +1 -0
  109. package/dist/elements/public/EmailTemplateForm/index.d.ts +9 -0
  110. package/dist/elements/public/EmailTemplateForm/index.js +11 -0
  111. package/dist/elements/public/EmailTemplateForm/index.js.map +1 -0
  112. package/dist/elements/public/EmailTemplateForm/types.d.ts +17 -0
  113. package/dist/elements/public/EmailTemplateForm/types.js +2 -0
  114. package/dist/elements/public/EmailTemplateForm/types.js.map +1 -0
  115. package/dist/elements/public/ItemsForm/ItemsForm.js +2 -2
  116. package/dist/elements/public/ItemsForm/ItemsForm.js.map +1 -1
  117. package/dist/elements/public/NucleonElement/serveFromCache.js +1 -0
  118. package/dist/elements/public/NucleonElement/serveFromCache.js.map +1 -1
  119. package/dist/elements/public/TaxForm/TaxForm.js +8 -4
  120. package/dist/elements/public/TaxForm/TaxForm.js.map +1 -1
  121. package/dist/elements/public/TemplateConfigForm/CountriesList.d.ts +23 -0
  122. package/dist/elements/public/TemplateConfigForm/CountriesList.js +138 -0
  123. package/dist/elements/public/TemplateConfigForm/CountriesList.js.map +1 -0
  124. package/dist/elements/public/TemplateConfigForm/CountryCard.d.ts +22 -0
  125. package/dist/elements/public/TemplateConfigForm/CountryCard.js +157 -0
  126. package/dist/elements/public/TemplateConfigForm/CountryCard.js.map +1 -0
  127. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.d.ts +88 -0
  128. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.js +1336 -0
  129. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.js.map +1 -0
  130. package/dist/elements/public/TemplateConfigForm/defaults.d.ts +2 -0
  131. package/dist/elements/public/TemplateConfigForm/defaults.js +95 -0
  132. package/dist/elements/public/TemplateConfigForm/defaults.js.map +1 -0
  133. package/dist/elements/public/TemplateConfigForm/index.d.ts +9 -0
  134. package/dist/elements/public/TemplateConfigForm/index.js +11 -0
  135. package/dist/elements/public/TemplateConfigForm/index.js.map +1 -0
  136. package/dist/elements/public/TemplateConfigForm/types.d.ts +150 -0
  137. package/dist/elements/public/TemplateConfigForm/types.js +2 -0
  138. package/dist/elements/public/TemplateConfigForm/types.js.map +1 -0
  139. package/dist/elements/public/TemplateForm/TemplateForm.d.ts +23 -1
  140. package/dist/elements/public/TemplateForm/TemplateForm.js +102 -58
  141. package/dist/elements/public/TemplateForm/TemplateForm.js.map +1 -1
  142. package/dist/elements/public/TemplateForm/types.d.ts +14 -0
  143. package/dist/elements/public/TemplateForm/types.js.map +1 -1
  144. package/dist/elements/public/index.d.ts +2 -0
  145. package/dist/elements/public/index.defined.d.ts +2 -0
  146. package/dist/elements/public/index.defined.js +2 -0
  147. package/dist/elements/public/index.defined.js.map +1 -1
  148. package/dist/elements/public/index.js +2 -0
  149. package/dist/elements/public/index.js.map +1 -1
  150. package/dist/mixins/themeable.js +125 -16
  151. package/dist/mixins/themeable.js.map +1 -1
  152. package/package.json +2 -7
  153. package/dist/cdn/shared-35502e88.js +0 -1
  154. package/dist/cdn/shared-50744508.js +0 -15
  155. package/dist/cdn/shared-5388f705.js +0 -1
  156. package/dist/cdn/shared-7f588649.js +0 -1
  157. package/dist/cdn/shared-9467cb31.js +0 -572
  158. package/dist/cdn/shared-b98f88c9.js +0 -369
  159. package/dist/cdn/shared-c0161e6a.js +0 -1
  160. package/dist/cdn/shared-dbcffd8e.js +0 -1
  161. package/dist/cdn/shared-e057788f.js +0 -1
  162. package/dist/cdn/shared-e21a2aac.js +0 -1
  163. package/dist/cdn/shared-ebbef842.js +0 -1
  164. package/dist/cdn/shared-fd5b81be.js +0 -1
@@ -0,0 +1,138 @@
1
+ import { ScopedElementsMixin } from '@open-wc/scoped-elements';
2
+ import { html } from 'lit-html';
3
+ import { CountryCard } from "./CountryCard.js";
4
+ import { NucleonElement } from "../NucleonElement/NucleonElement.js";
5
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
6
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
7
+ import { classMap } from "../../../utils/class-map.js";
8
+ import { ifDefined } from 'lit-html/directives/if-defined';
9
+ const Base = ScopedElementsMixin(ThemeableMixin(TranslatableMixin(NucleonElement)));
10
+ export class CountriesList extends Base {
11
+ constructor() {
12
+ super(...arguments);
13
+ this.countries = {};
14
+ this.disabled = false;
15
+ this.readonly = false;
16
+ this.regions = '';
17
+ this.country = '';
18
+ }
19
+ static get scopedElements() {
20
+ return {
21
+ 'x-country-card': CountryCard,
22
+ 'iron-icon': customElements.get('iron-icon'),
23
+ };
24
+ }
25
+ static get properties() {
26
+ return {
27
+ ...super.properties,
28
+ countries: { type: Object },
29
+ disabled: { type: Boolean },
30
+ readonly: { type: Boolean },
31
+ regions: { type: String },
32
+ country: { type: String },
33
+ };
34
+ }
35
+ render() {
36
+ var _a, _b;
37
+ return html `
38
+ <div>
39
+ <div class="space-y-s">
40
+ ${Object.entries(this.countries).map(([country, regions]) => {
41
+ var _a, _b;
42
+ let regionsLink;
43
+ try {
44
+ const url = new URL(this.regions);
45
+ url.searchParams.set('country_code', country);
46
+ regionsLink = url.toString();
47
+ }
48
+ catch (_c) {
49
+ regionsLink = '';
50
+ }
51
+ return html `
52
+ <x-country-card
53
+ regions=${JSON.stringify(regions === '*' ? [] : regions)}
54
+ code=${country}
55
+ name=${ifDefined((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values[country]) === null || _b === void 0 ? void 0 : _b.default)}
56
+ href=${regionsLink}
57
+ lang=${this.lang}
58
+ ns=${this.ns}
59
+ ?disabled=${this.disabled}
60
+ ?readonly=${this.readonly}
61
+ @update:regions=${(evt) => {
62
+ const newCountries = { ...this.countries };
63
+ const newRegions = evt.currentTarget.regions;
64
+ newCountries[country] = newRegions.length ? newRegions : '*';
65
+ this.countries = newCountries;
66
+ this.dispatchEvent(new CustomEvent('update:countries'));
67
+ }}
68
+ @delete=${() => {
69
+ const newCountries = { ...this.countries };
70
+ delete newCountries[country];
71
+ this.countries = newCountries;
72
+ this.dispatchEvent(new CustomEvent('update:countries'));
73
+ }}
74
+ >
75
+ </x-country-card>
76
+ `;
77
+ })}
78
+
79
+ <div
80
+ class=${classMap({
81
+ 'h-m flex items-center rounded transition-colors': true,
82
+ 'border border-contrast-10 ring-primary-50': true,
83
+ 'hover-border-contrast-40': !this.disabled,
84
+ 'focus-within-ring-1 focus-within-border-primary-50': !this.disabled,
85
+ 'flex': !this.readonly,
86
+ 'hidden': this.readonly,
87
+ })}
88
+ >
89
+ <input
90
+ placeholder=${this.t('add_country')}
91
+ class="w-full bg-transparent appearance-none h-m text-s px-m focus-outline-none"
92
+ list="list"
93
+ .value=${this.country}
94
+ ?disabled=${this.disabled}
95
+ ?readonly=${this.readonly}
96
+ @keydown=${(evt) => {
97
+ if (evt.key === 'Enter' && this.country)
98
+ this.__addCountry();
99
+ }}
100
+ @input=${(evt) => {
101
+ const target = evt.currentTarget;
102
+ this.country = target.value;
103
+ }}
104
+ />
105
+
106
+ <button
107
+ class=${classMap({
108
+ 'mr-xs flex-shrink-0': true,
109
+ 'flex items-center justify-center rounded-full transition-colors': true,
110
+ 'bg-contrast-5 text-disabled cursor-default': !this.country,
111
+ 'bg-success-10 text-success cursor-pointer': !!this.country,
112
+ 'hover-bg-success hover-text-success-contrast': !!this.country,
113
+ 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.country,
114
+ })}
115
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
116
+ ?disabled=${!this.country || this.disabled}
117
+ @click=${this.__addCountry}
118
+ >
119
+ <iron-icon icon="icons:add" class="icon-inline text-m"></iron-icon>
120
+ </button>
121
+ </div>
122
+ </div>
123
+
124
+ <datalist id="list">
125
+ ${Object.values((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values) !== null && _b !== void 0 ? _b : {}).map(country => {
126
+ return html `<option value=${country.cc2}>${country.default}</option>`;
127
+ })}
128
+ </datalist>
129
+ </div>
130
+ `;
131
+ }
132
+ __addCountry() {
133
+ this.countries = { ...this.countries, [this.country]: '*' };
134
+ this.country = '';
135
+ this.dispatchEvent(new CustomEvent('update:countries'));
136
+ }
137
+ }
138
+ //# sourceMappingURL=CountriesList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CountriesList.js","sourceRoot":"","sources":["../../../../src/elements/public/TemplateConfigForm/CountriesList.ts"],"names":[],"mappings":"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","sourcesContent":["import { ScopedElementsMap, ScopedElementsMixin } from '@open-wc/scoped-elements';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { CountryCard } from './CountryCard';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { PropertyDeclarations } from 'lit-element';\nimport { Rels } from '@foxy.io/sdk/backend';\nimport { Resource } from '@foxy.io/sdk/core';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\nimport { ifDefined } from 'lit-html/directives/if-defined';\n\nconst Base = ScopedElementsMixin(ThemeableMixin(TranslatableMixin(NucleonElement)));\n\nexport class CountriesList extends Base<Resource<Rels.Countries>> {\n static get scopedElements(): ScopedElementsMap {\n return {\n 'x-country-card': CountryCard,\n 'iron-icon': customElements.get('iron-icon'),\n };\n }\n\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n countries: { type: Object },\n disabled: { type: Boolean },\n readonly: { type: Boolean },\n regions: { type: String },\n country: { type: String },\n };\n }\n\n countries: Record<string, '*' | string[]> = {};\n\n disabled = false;\n\n readonly = false;\n\n regions = '';\n\n country = '';\n\n render(): TemplateResult {\n return html`\n <div>\n <div class=\"space-y-s\">\n ${Object.entries(this.countries).map(([country, regions]) => {\n let regionsLink: string;\n\n try {\n const url = new URL(this.regions);\n url.searchParams.set('country_code', country);\n regionsLink = url.toString();\n } catch {\n regionsLink = '';\n }\n\n return html`\n <x-country-card\n regions=${JSON.stringify(regions === '*' ? [] : regions)}\n code=${country}\n name=${ifDefined(this.data?.values[country]?.default)}\n href=${regionsLink}\n lang=${this.lang}\n ns=${this.ns}\n ?disabled=${this.disabled}\n ?readonly=${this.readonly}\n @update:regions=${(evt: CustomEvent) => {\n const newCountries = { ...this.countries };\n const newRegions = (evt.currentTarget as CountryCard).regions;\n\n newCountries[country] = newRegions.length ? newRegions : '*';\n this.countries = newCountries;\n\n this.dispatchEvent(new CustomEvent('update:countries'));\n }}\n @delete=${() => {\n const newCountries = { ...this.countries };\n delete newCountries[country];\n this.countries = newCountries;\n\n this.dispatchEvent(new CustomEvent('update:countries'));\n }}\n >\n </x-country-card>\n `;\n })}\n\n <div\n class=${classMap({\n 'h-m flex items-center rounded transition-colors': true,\n 'border border-contrast-10 ring-primary-50': true,\n 'hover-border-contrast-40': !this.disabled,\n 'focus-within-ring-1 focus-within-border-primary-50': !this.disabled,\n 'flex': !this.readonly,\n 'hidden': this.readonly,\n })}\n >\n <input\n placeholder=${this.t('add_country')}\n class=\"w-full bg-transparent appearance-none h-m text-s px-m focus-outline-none\"\n list=\"list\"\n .value=${this.country}\n ?disabled=${this.disabled}\n ?readonly=${this.readonly}\n @keydown=${(evt: KeyboardEvent) => {\n if (evt.key === 'Enter' && this.country) this.__addCountry();\n }}\n @input=${(evt: InputEvent) => {\n const target = evt.currentTarget as HTMLInputElement;\n this.country = target.value;\n }}\n />\n\n <button\n class=${classMap({\n 'mr-xs flex-shrink-0': true,\n 'flex items-center justify-center rounded-full transition-colors': true,\n 'bg-contrast-5 text-disabled cursor-default': !this.country,\n 'bg-success-10 text-success cursor-pointer': !!this.country,\n 'hover-bg-success hover-text-success-contrast': !!this.country,\n 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.country,\n })}\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\n ?disabled=${!this.country || this.disabled}\n @click=${this.__addCountry}\n >\n <iron-icon icon=\"icons:add\" class=\"icon-inline text-m\"></iron-icon>\n </button>\n </div>\n </div>\n\n <datalist id=\"list\">\n ${Object.values(this.data?.values ?? {}).map(country => {\n return html`<option value=${country.cc2}>${country.default}</option>`;\n })}\n </datalist>\n </div>\n `;\n }\n\n private __addCountry() {\n this.countries = { ...this.countries, [this.country]: '*' };\n this.country = '';\n this.dispatchEvent(new CustomEvent('update:countries'));\n }\n}\n"]}
@@ -0,0 +1,22 @@
1
+ import { TemplateResult } from 'lit-html';
2
+ import { NucleonElement } from '../NucleonElement/NucleonElement';
3
+ import { PropertyDeclarations } from 'lit-element';
4
+ import { Rels } from '@foxy.io/sdk/backend';
5
+ import { Resource } from '@foxy.io/sdk/core';
6
+ declare const Base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
7
+ defaultNS: string;
8
+ } & {
9
+ styles: import("lit-element").CSSResultArray;
10
+ } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost>;
11
+ export declare class CountryCard extends Base<Resource<Rels.Regions>> {
12
+ static get properties(): PropertyDeclarations;
13
+ disabled: boolean;
14
+ readonly: boolean;
15
+ regions: string[];
16
+ region: string;
17
+ name: string;
18
+ code: string;
19
+ render(): TemplateResult;
20
+ private __addRegion;
21
+ }
22
+ export {};
@@ -0,0 +1,157 @@
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 Base = ConfigurableMixin(ThemeableMixin(TranslatableMixin(NucleonElement)));
8
+ export class CountryCard extends Base {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.disabled = false;
12
+ this.readonly = false;
13
+ this.regions = [];
14
+ this.region = '';
15
+ this.name = '';
16
+ this.code = '';
17
+ }
18
+ static get properties() {
19
+ return {
20
+ ...super.properties,
21
+ disabled: { type: Boolean },
22
+ readonly: { type: Boolean },
23
+ regions: { type: Array },
24
+ region: { type: String },
25
+ name: { type: String },
26
+ code: { type: String },
27
+ };
28
+ }
29
+ render() {
30
+ var _a, _b;
31
+ return html `
32
+ <div
33
+ class=${classMap({
34
+ 'border border-contrast-10 rounded text-s': true,
35
+ 'text-disabled': this.disabled,
36
+ })}
37
+ >
38
+ <div class="h-m flex justify-between items-center border-b border-contrast-10">
39
+ <div class="ml-m">
40
+ <span>${this.name || this.code}</span>
41
+ ${this.name ? html `<span class="text-secondary">${this.code}</span>` : ''}
42
+ </div>
43
+
44
+ <button
45
+ class=${classMap({
46
+ 'mr-xs items-center justify-center rounded-full transition-colors': true,
47
+ 'hover-bg-error-10 hover-text-error': !this.disabled,
48
+ 'focus-outline-none focus-ring-2 ring-inset ring-error-50': !this.disabled,
49
+ 'cursor-default': this.disabled,
50
+ 'flex': !this.readonly,
51
+ 'hidden': this.readonly,
52
+ })}
53
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
54
+ ?disabled=${this.disabled}
55
+ @click=${() => this.dispatchEvent(new CustomEvent('delete'))}
56
+ >
57
+ <iron-icon icon="icons:close" class="icon-inline text-m"></iron-icon>
58
+ </button>
59
+ </div>
60
+
61
+ <div class="flex flex-wrap p-xs">
62
+ ${this.regions.map(region => {
63
+ var _a, _b;
64
+ const name = (_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values[region]) === null || _b === void 0 ? void 0 : _b.default;
65
+ const code = region;
66
+ return html `
67
+ <div
68
+ class="flex items-center border border-contrast-10 h-s m-xs"
69
+ style="border-radius: var(--lumo-size-s)"
70
+ >
71
+ <span class="mx-s">
72
+ <span>${name || code}</span>
73
+ ${name ? html `<span class="text-secondary">${code}</span>` : ''}
74
+ </span>
75
+
76
+ <button
77
+ class=${classMap({
78
+ 'items-center justify-center rounded-full transition-colors': true,
79
+ 'hover-bg-error-10 hover-text-error': !this.disabled,
80
+ 'focus-outline-none focus-ring-2 ring-inset ring-error-50': !this.disabled,
81
+ 'cursor-default': this.disabled,
82
+ 'flex': !this.readonly,
83
+ 'hidden': this.readonly,
84
+ })}
85
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
86
+ ?disabled=${this.disabled}
87
+ @click=${() => {
88
+ this.regions = this.regions.filter(value => value !== region);
89
+ this.dispatchEvent(new CustomEvent('update:regions'));
90
+ }}
91
+ >
92
+ <iron-icon icon="icons:close" class="icon-inline text-m"></iron-icon>
93
+ </button>
94
+ </div>
95
+ `;
96
+ })}
97
+
98
+ <div
99
+ style="border-radius: var(--lumo-size-s)"
100
+ class=${classMap({
101
+ 'h-s m-xs items-center transition-colors border border-contrast-10': true,
102
+ 'hover-border-contrast-40': !this.disabled,
103
+ 'focus-within-ring-1 ring-primary-50 focus-within-border-primary-50': !this.disabled,
104
+ 'flex': !this.readonly,
105
+ 'hidden': this.readonly,
106
+ })}
107
+ >
108
+ <input
109
+ placeholder=${this.t('add_region')}
110
+ class="bg-transparent appearance-none h-s text-s px-s focus-outline-none"
111
+ style="width: 8rem"
112
+ list="list"
113
+ .value=${this.region}
114
+ ?disabled=${this.disabled}
115
+ @keydown=${(evt) => {
116
+ if (evt.key === 'Enter' && this.region)
117
+ this.__addRegion();
118
+ }}
119
+ @input=${(evt) => {
120
+ const target = evt.currentTarget;
121
+ this.region = target.value;
122
+ }}
123
+ />
124
+
125
+ <button
126
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
127
+ class=${classMap({
128
+ 'flex-shrink-0': true,
129
+ 'flex items-center justify-center rounded-full transition-colors': true,
130
+ 'bg-contrast-5 text-disabled cursor-default': !this.region,
131
+ 'bg-success-10 text-success cursor-pointer': !!this.region,
132
+ 'hover-bg-success hover-text-success-contrast': !!this.region,
133
+ 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.region,
134
+ })}
135
+ ?disabled=${!this.region}
136
+ @click=${this.__addRegion}
137
+ >
138
+ <iron-icon icon="icons:add" class="icon-inline text-m"></iron-icon>
139
+ </button>
140
+ </div>
141
+
142
+ <datalist id="list">
143
+ ${Object.values((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values) !== null && _b !== void 0 ? _b : {}).map(region => {
144
+ return html `<option value=${region.code}>${region.default}</option>`;
145
+ })}
146
+ </datalist>
147
+ </div>
148
+ </div>
149
+ `;
150
+ }
151
+ __addRegion() {
152
+ this.regions = [...new Set([...this.regions, this.region])];
153
+ this.region = '';
154
+ this.dispatchEvent(new CustomEvent('update:regions'));
155
+ }
156
+ }
157
+ //# sourceMappingURL=CountryCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CountryCard.js","sourceRoot":"","sources":["../../../../src/elements/public/TemplateConfigForm/CountryCard.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhD,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,cAAc,EAAE,4CAAyC;AAIlE,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AAEpD,MAAM,IAAI,GAAG,iBAAiB,CAAC,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC;AAElF,MAAM,OAAO,WAAY,SAAQ,IAA4B;IAA7D;;QAaE,aAAQ,GAAG,KAAK,CAAC;QAEjB,aAAQ,GAAG,KAAK,CAAC;QAEjB,YAAO,GAAa,EAAE,CAAC;QAEvB,WAAM,GAAG,EAAE,CAAC;QAEZ,SAAI,GAAG,EAAE,CAAC;QAEV,SAAI,GAAG,EAAE,CAAC;IAgIZ,CAAC;IAtJC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,QAAQ,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;YAC3B,QAAQ,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;YAC3B,OAAO,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE;YACxB,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;YACxB,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;YACtB,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACvB,CAAC;IACJ,CAAC;IAcD,MAAM;;QACJ,OAAO,IAAI,CAAA;;gBAEC,QAAQ,CAAC;YACf,0CAA0C,EAAE,IAAI;YAChD,eAAe,EAAE,IAAI,CAAC,QAAQ;SAC/B,CAAC;;;;oBAIU,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI;cAC5B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA,gCAAgC,IAAI,CAAC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE;;;;oBAIjE,QAAQ,CAAC;YACf,kEAAkE,EAAE,IAAI;YACxE,oCAAoC,EAAE,CAAC,IAAI,CAAC,QAAQ;YACpD,0DAA0D,EAAE,CAAC,IAAI,CAAC,QAAQ;YAC1E,gBAAgB,EAAE,IAAI,CAAC,QAAQ;YAC/B,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ;YACtB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;;wBAEU,IAAI,CAAC,QAAQ;qBAChB,GAAG,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,CAAC;;;;;;;YAO5D,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;;YAC1B,MAAM,IAAI,eAAG,IAAI,CAAC,IAAI,0CAAE,MAAM,CAAC,MAAM,2CAAG,OAAO,CAAC;YAChD,MAAM,IAAI,GAAG,MAAM,CAAC;YAEpB,OAAO,IAAI,CAAA;;;;;;0BAMG,IAAI,IAAI,IAAI;oBAClB,IAAI,CAAC,CAAC,CAAC,IAAI,CAAA,gCAAgC,IAAI,SAAS,CAAC,CAAC,CAAC,EAAE;;;;0BAIvD,QAAQ,CAAC;gBACf,4DAA4D,EAAE,IAAI;gBAClE,oCAAoC,EAAE,CAAC,IAAI,CAAC,QAAQ;gBACpD,0DAA0D,EAAE,CAAC,IAAI,CAAC,QAAQ;gBAC1E,gBAAgB,EAAE,IAAI,CAAC,QAAQ;gBAC/B,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ;gBACtB,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC;;8BAEU,IAAI,CAAC,QAAQ;2BAChB,GAAG,EAAE;gBACZ,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,KAAK,MAAM,CAAC,CAAC;gBAC9D,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;YACxD,CAAC;;;;;aAKN,CAAC;QACJ,CAAC,CAAC;;;;oBAIQ,QAAQ,CAAC;YACf,mEAAmE,EAAE,IAAI;YACzE,0BAA0B,EAAE,CAAC,IAAI,CAAC,QAAQ;YAC1C,oEAAoE,EAAE,CAAC,IAAI,CAAC,QAAQ;YACpF,MAAM,EAAE,CAAC,IAAI,CAAC,QAAQ;YACtB,QAAQ,EAAE,IAAI,CAAC,QAAQ;SACxB,CAAC;;;4BAGc,IAAI,CAAC,CAAC,CAAC,YAAY,CAAC;;;;uBAIzB,IAAI,CAAC,MAAM;0BACR,IAAI,CAAC,QAAQ;yBACd,CAAC,GAAkB,EAAE,EAAE;YAChC,IAAI,GAAG,CAAC,GAAG,KAAK,OAAO,IAAI,IAAI,CAAC,MAAM;gBAAE,IAAI,CAAC,WAAW,EAAE,CAAC;QAC7D,CAAC;uBACQ,CAAC,GAAe,EAAE,EAAE;YAC3B,MAAM,MAAM,GAAG,GAAG,CAAC,aAAiC,CAAC;YACrD,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC;QAC7B,CAAC;;;;;sBAKO,QAAQ,CAAC;YACf,eAAe,EAAE,IAAI;YACrB,iEAAiE,EAAE,IAAI;YACvE,4CAA4C,EAAE,CAAC,IAAI,CAAC,MAAM;YAC1D,2CAA2C,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM;YAC1D,8CAA8C,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM;YAC7D,4DAA4D,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM;SAC5E,CAAC;0BACU,CAAC,IAAI,CAAC,MAAM;uBACf,IAAI,CAAC,WAAW;;;;;;;cAOzB,MAAM,CAAC,MAAM,aAAC,IAAI,CAAC,IAAI,0CAAE,MAAM,mCAAI,EAAE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE;YACpD,OAAO,IAAI,CAAA,iBAAiB,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,OAAO,WAAW,CAAC;QACvE,CAAC,CAAC;;;;KAIT,CAAC;IACJ,CAAC;IAEO,WAAW;QACjB,IAAI,CAAC,OAAO,GAAG,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAC5D,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,aAAa,CAAC,IAAI,WAAW,CAAC,gBAAgB,CAAC,CAAC,CAAC;IACxD,CAAC;CACF","sourcesContent":["import { TemplateResult, html } from 'lit-html';\n\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { PropertyDeclarations } from 'lit-element';\nimport { Rels } from '@foxy.io/sdk/backend';\nimport { Resource } from '@foxy.io/sdk/core';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\n\nconst Base = ConfigurableMixin(ThemeableMixin(TranslatableMixin(NucleonElement)));\n\nexport class CountryCard extends Base<Resource<Rels.Regions>> {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n disabled: { type: Boolean },\n readonly: { type: Boolean },\n regions: { type: Array },\n region: { type: String },\n name: { type: String },\n code: { type: String },\n };\n }\n\n disabled = false;\n\n readonly = false;\n\n regions: string[] = [];\n\n region = '';\n\n name = '';\n\n code = '';\n\n render(): TemplateResult {\n return html`\n <div\n class=${classMap({\n 'border border-contrast-10 rounded text-s': true,\n 'text-disabled': this.disabled,\n })}\n >\n <div class=\"h-m flex justify-between items-center border-b border-contrast-10\">\n <div class=\"ml-m\">\n <span>${this.name || this.code}</span>\n ${this.name ? html`<span class=\"text-secondary\">${this.code}</span>` : ''}\n </div>\n\n <button\n class=${classMap({\n 'mr-xs items-center justify-center rounded-full transition-colors': true,\n 'hover-bg-error-10 hover-text-error': !this.disabled,\n 'focus-outline-none focus-ring-2 ring-inset ring-error-50': !this.disabled,\n 'cursor-default': this.disabled,\n 'flex': !this.readonly,\n 'hidden': this.readonly,\n })}\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\n ?disabled=${this.disabled}\n @click=${() => this.dispatchEvent(new CustomEvent('delete'))}\n >\n <iron-icon icon=\"icons:close\" class=\"icon-inline text-m\"></iron-icon>\n </button>\n </div>\n\n <div class=\"flex flex-wrap p-xs\">\n ${this.regions.map(region => {\n const name = this.data?.values[region]?.default;\n const code = region;\n\n return html`\n <div\n class=\"flex items-center border border-contrast-10 h-s m-xs\"\n style=\"border-radius: var(--lumo-size-s)\"\n >\n <span class=\"mx-s\">\n <span>${name || code}</span>\n ${name ? html`<span class=\"text-secondary\">${code}</span>` : ''}\n </span>\n\n <button\n class=${classMap({\n 'items-center justify-center rounded-full transition-colors': true,\n 'hover-bg-error-10 hover-text-error': !this.disabled,\n 'focus-outline-none focus-ring-2 ring-inset ring-error-50': !this.disabled,\n 'cursor-default': this.disabled,\n 'flex': !this.readonly,\n 'hidden': this.readonly,\n })}\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\n ?disabled=${this.disabled}\n @click=${() => {\n this.regions = this.regions.filter(value => value !== region);\n this.dispatchEvent(new CustomEvent('update:regions'));\n }}\n >\n <iron-icon icon=\"icons:close\" class=\"icon-inline text-m\"></iron-icon>\n </button>\n </div>\n `;\n })}\n\n <div\n style=\"border-radius: var(--lumo-size-s)\"\n class=${classMap({\n 'h-s m-xs items-center transition-colors border border-contrast-10': true,\n 'hover-border-contrast-40': !this.disabled,\n 'focus-within-ring-1 ring-primary-50 focus-within-border-primary-50': !this.disabled,\n 'flex': !this.readonly,\n 'hidden': this.readonly,\n })}\n >\n <input\n placeholder=${this.t('add_region')}\n class=\"bg-transparent appearance-none h-s text-s px-s focus-outline-none\"\n style=\"width: 8rem\"\n list=\"list\"\n .value=${this.region}\n ?disabled=${this.disabled}\n @keydown=${(evt: KeyboardEvent) => {\n if (evt.key === 'Enter' && this.region) this.__addRegion();\n }}\n @input=${(evt: InputEvent) => {\n const target = evt.currentTarget as HTMLInputElement;\n this.region = target.value;\n }}\n />\n\n <button\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\n class=${classMap({\n 'flex-shrink-0': true,\n 'flex items-center justify-center rounded-full transition-colors': true,\n 'bg-contrast-5 text-disabled cursor-default': !this.region,\n 'bg-success-10 text-success cursor-pointer': !!this.region,\n 'hover-bg-success hover-text-success-contrast': !!this.region,\n 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.region,\n })}\n ?disabled=${!this.region}\n @click=${this.__addRegion}\n >\n <iron-icon icon=\"icons:add\" class=\"icon-inline text-m\"></iron-icon>\n </button>\n </div>\n\n <datalist id=\"list\">\n ${Object.values(this.data?.values ?? {}).map(region => {\n return html`<option value=${region.code}>${region.default}</option>`;\n })}\n </datalist>\n </div>\n </div>\n `;\n }\n\n private __addRegion() {\n this.regions = [...new Set([...this.regions, this.region])];\n this.region = '';\n this.dispatchEvent(new CustomEvent('update:regions'));\n }\n}\n"]}
@@ -0,0 +1,88 @@
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 { PropertyDeclarations } from 'lit-element';
6
+ declare const Base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
7
+ defaultNS: string;
8
+ } & {
9
+ styles: import("lit-element").CSSResultArray;
10
+ } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost> & import("@open-wc/dedupe-mixin").Constructor<import("@open-wc/scoped-elements/src/types").ScopedElementsHost>;
11
+ /**
12
+ * Form element for creating or editing template configs (`fx:template_config`).
13
+ *
14
+ * @slot cart-type:before
15
+ * @slot cart-type:after
16
+ *
17
+ * @slot foxycomplete:before
18
+ * @slot foxycomplete:after
19
+ *
20
+ * @slot locations:before
21
+ * @slot locations:after
22
+ *
23
+ * @slot hidden-fields:before
24
+ * @slot hidden-fields:after
25
+ *
26
+ * @slot cards:before
27
+ * @slot cards:after
28
+ *
29
+ * @slot checkout-type:before
30
+ * @slot checkout-type:after
31
+ *
32
+ * @slot consent:before
33
+ * @slot consent:after
34
+ *
35
+ * @slot fields:before
36
+ * @slot fields:after
37
+ *
38
+ * @slot google-analytics:before
39
+ * @slot google-analytics:after
40
+ *
41
+ * @slot segment-io:before
42
+ * @slot segment-io:after
43
+ *
44
+ * @slot troubleshooting:before
45
+ * @slot troubleshooting:after
46
+ *
47
+ * @slot custom-config:before
48
+ * @slot custom-config:after
49
+ *
50
+ * @slot header:before
51
+ * @slot header:after
52
+ *
53
+ * @slot custom-fields:before
54
+ * @slot custom-fields:after
55
+ *
56
+ * @slot footer:before
57
+ * @slot footer:after
58
+ *
59
+ * @element foxy-template-config-form
60
+ * @since 1.14.0
61
+ */
62
+ export declare class TemplateConfigForm extends Base<Data> {
63
+ static get scopedElements(): ScopedElementsMap;
64
+ static get properties(): PropertyDeclarations;
65
+ templates: Templates;
66
+ /** URI of the `fx:countries` hAPI resource. */
67
+ countries: string;
68
+ /** URI of the `fx:regions` hAPI resource. */
69
+ regions: string;
70
+ private __addHiddenFieldInputValue;
71
+ render(): TemplateResult;
72
+ private __renderCartType;
73
+ private __renderFoxycomplete;
74
+ private __renderLocations;
75
+ private __renderHiddenFields;
76
+ private __renderCards;
77
+ private __renderCheckoutType;
78
+ private __renderConsent;
79
+ private __renderFields;
80
+ private __renderGoogleAnalytics;
81
+ private __renderSegmentIo;
82
+ private __renderTroubleshooting;
83
+ private __renderCustomConfig;
84
+ private __renderHeader;
85
+ private __renderCustomFields;
86
+ private __renderFooter;
87
+ }
88
+ export {};