@foxy.io/elements 1.14.0-beta.2 → 1.14.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 (152) 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 +10 -10
  17. package/dist/cdn/foxy-customer-portal.js +2 -2
  18. package/dist/cdn/foxy-customer.js +2 -2
  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 -1
  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 +2 -2
  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 +14 -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-d4dad105.js → shared-00563cb0.js} +1 -1
  46. package/dist/cdn/shared-09feabf8.js +1 -0
  47. package/dist/cdn/{shared-6783c996.js → shared-0ba88744.js} +1 -1
  48. package/dist/cdn/shared-0ced76a0.js +358 -0
  49. package/dist/cdn/{shared-dbbe03f9.js → shared-16e28f3b.js} +1 -1
  50. package/dist/cdn/{shared-f4119f12.js → shared-16f72e27.js} +1 -1
  51. package/dist/cdn/shared-1761daef.js +15 -0
  52. package/dist/cdn/{shared-35415106.js → shared-1bafffd0.js} +1 -1
  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-e9920617.js → shared-34b2c1e2.js} +1 -1
  56. package/dist/cdn/shared-3f35fa81.js +1 -0
  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-5d286626.js → shared-4d3c7828.js} +1 -1
  60. package/dist/cdn/{shared-151ca103.js → shared-50c7a176.js} +5 -5
  61. package/dist/cdn/{shared-f0199313.js → shared-593f7e2c.js} +1 -1
  62. package/dist/cdn/shared-59e44f29.js +1 -0
  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-691da586.js +1 -0
  66. package/dist/cdn/shared-6b7602c7.js +1 -0
  67. package/dist/cdn/{shared-98ee7fad.js → shared-6d45a07b.js} +1 -1
  68. package/dist/cdn/{shared-99f45065.js → shared-6ecbc785.js} +1 -1
  69. package/dist/cdn/shared-6f7f752e.js +1 -0
  70. package/dist/cdn/shared-7629a1a5.js +314 -0
  71. package/dist/cdn/shared-8edee4e1.js +264 -0
  72. package/dist/cdn/{shared-84fa75d9.js → shared-9221e6b2.js} +1 -1
  73. package/dist/cdn/{shared-2860a3d3.js → shared-94b0ae99.js} +2 -2
  74. package/dist/cdn/shared-a46edf4b.js +1 -0
  75. package/dist/cdn/{shared-566252ac.js → shared-a6c047b1.js} +1 -1
  76. package/dist/cdn/shared-ace85f1b.js +1 -0
  77. package/dist/cdn/{shared-54702b33.js → shared-b0f0e8b5.js} +1 -1
  78. package/dist/cdn/{shared-ed4ed7a5.js → shared-b710881a.js} +2 -2
  79. package/dist/cdn/{shared-3ae39e52.js → shared-bb824ab4.js} +3 -3
  80. package/dist/cdn/{shared-f2a4fd27.js → shared-c66e9946.js} +1 -1
  81. package/dist/cdn/shared-d8852c42.js +1 -0
  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-747b0842.js → shared-ff79f3f9.js} +1 -1
  87. package/dist/cdn/translations/shared/en.json +83 -1
  88. package/dist/elements/private/Checkbox/Checkbox.js +5 -1
  89. package/dist/elements/private/Checkbox/Checkbox.js.map +1 -1
  90. package/dist/elements/private/Choice/Choice.js +3 -3
  91. package/dist/elements/private/Choice/Choice.js.map +1 -1
  92. package/dist/elements/private/Group/Group.js +1 -1
  93. package/dist/elements/private/Group/Group.js.map +1 -1
  94. package/dist/elements/private/I18N/I18N.js +1 -1
  95. package/dist/elements/private/I18N/I18N.js.map +1 -1
  96. package/dist/elements/public/AddressForm/AddressForm.js +8 -4
  97. package/dist/elements/public/AddressForm/AddressForm.js.map +1 -1
  98. package/dist/elements/public/AttributeForm/AttributeForm.js +8 -4
  99. package/dist/elements/public/AttributeForm/AttributeForm.js.map +1 -1
  100. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js +8 -4
  101. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js.map +1 -1
  102. package/dist/elements/public/CustomerForm/CustomerForm.js +8 -4
  103. package/dist/elements/public/CustomerForm/CustomerForm.js.map +1 -1
  104. package/dist/elements/public/EmailTemplateForm/EmailTemplateForm.js +10 -6
  105. package/dist/elements/public/EmailTemplateForm/EmailTemplateForm.js.map +1 -1
  106. package/dist/elements/public/ItemsForm/ItemsForm.js +2 -2
  107. package/dist/elements/public/ItemsForm/ItemsForm.js.map +1 -1
  108. package/dist/elements/public/NucleonElement/serveFromCache.js +1 -0
  109. package/dist/elements/public/NucleonElement/serveFromCache.js.map +1 -1
  110. package/dist/elements/public/TaxForm/TaxForm.js +8 -4
  111. package/dist/elements/public/TaxForm/TaxForm.js.map +1 -1
  112. package/dist/elements/public/TemplateConfigForm/CountriesList.d.ts +23 -0
  113. package/dist/elements/public/TemplateConfigForm/CountriesList.js +129 -0
  114. package/dist/elements/public/TemplateConfigForm/CountriesList.js.map +1 -0
  115. package/dist/elements/public/TemplateConfigForm/CountryCard.d.ts +20 -0
  116. package/dist/elements/public/TemplateConfigForm/CountryCard.js +125 -0
  117. package/dist/elements/public/TemplateConfigForm/CountryCard.js.map +1 -0
  118. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.d.ts +34 -0
  119. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.js +1117 -0
  120. package/dist/elements/public/TemplateConfigForm/TemplateConfigForm.js.map +1 -0
  121. package/dist/elements/public/TemplateConfigForm/defaults.d.ts +2 -0
  122. package/dist/elements/public/TemplateConfigForm/defaults.js +95 -0
  123. package/dist/elements/public/TemplateConfigForm/defaults.js.map +1 -0
  124. package/dist/elements/public/TemplateConfigForm/index.d.ts +9 -0
  125. package/dist/elements/public/TemplateConfigForm/index.js +11 -0
  126. package/dist/elements/public/TemplateConfigForm/index.js.map +1 -0
  127. package/dist/elements/public/TemplateConfigForm/types.d.ts +116 -0
  128. package/dist/elements/public/TemplateConfigForm/types.js +2 -0
  129. package/dist/elements/public/TemplateConfigForm/types.js.map +1 -0
  130. package/dist/elements/public/TemplateForm/TemplateForm.js +10 -6
  131. package/dist/elements/public/TemplateForm/TemplateForm.js.map +1 -1
  132. package/dist/elements/public/index.d.ts +1 -0
  133. package/dist/elements/public/index.defined.d.ts +1 -0
  134. package/dist/elements/public/index.defined.js +1 -0
  135. package/dist/elements/public/index.defined.js.map +1 -1
  136. package/dist/elements/public/index.js +1 -0
  137. package/dist/elements/public/index.js.map +1 -1
  138. package/dist/mixins/themeable.js +107 -12
  139. package/dist/mixins/themeable.js.map +1 -1
  140. package/package.json +2 -7
  141. package/dist/cdn/shared-35502e88.js +0 -1
  142. package/dist/cdn/shared-50744508.js +0 -15
  143. package/dist/cdn/shared-5388f705.js +0 -1
  144. package/dist/cdn/shared-7f588649.js +0 -1
  145. package/dist/cdn/shared-9467cb31.js +0 -572
  146. package/dist/cdn/shared-b98f88c9.js +0 -369
  147. package/dist/cdn/shared-c0161e6a.js +0 -1
  148. package/dist/cdn/shared-dbcffd8e.js +0 -1
  149. package/dist/cdn/shared-e057788f.js +0 -1
  150. package/dist/cdn/shared-e21a2aac.js +0 -1
  151. package/dist/cdn/shared-ebbef842.js +0 -1
  152. package/dist/cdn/shared-fd5b81be.js +0 -1
@@ -0,0 +1,129 @@
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="h-m flex items-center rounded transition-colors border border-contrast-10 hover-border-contrast-40 focus-within-ring-1 focus-within-ring-primary-50 focus-within-border-primary-50"
81
+ >
82
+ <input
83
+ placeholder=${this.t('add_country')}
84
+ class="w-full bg-transparent appearance-none h-m text-s px-m focus-outline-none"
85
+ list="list"
86
+ .value=${this.country}
87
+ @keydown=${(evt) => {
88
+ if (evt.key === 'Enter' && this.country)
89
+ this.__addCountry();
90
+ }}
91
+ @input=${(evt) => {
92
+ const target = evt.currentTarget;
93
+ this.country = target.value;
94
+ }}
95
+ />
96
+
97
+ <button
98
+ class=${classMap({
99
+ 'mr-xs flex-shrink-0': true,
100
+ 'flex items-center justify-center rounded-full transition-colors': true,
101
+ 'bg-contrast-5 text-disabled cursor-default': !this.country,
102
+ 'bg-success-10 text-success cursor-pointer': !!this.country,
103
+ 'hover-bg-success hover-text-success-contrast': !!this.country,
104
+ 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.country,
105
+ })}
106
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
107
+ ?disabled=${!this.country}
108
+ @click=${this.__addCountry}
109
+ >
110
+ <iron-icon icon="icons:add" class="icon-inline text-m"></iron-icon>
111
+ </button>
112
+ </div>
113
+ </div>
114
+
115
+ <datalist id="list">
116
+ ${Object.values((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values) !== null && _b !== void 0 ? _b : {}).map(country => {
117
+ return html `<option value=${country.cc2}>${country.default}</option>`;
118
+ })}
119
+ </datalist>
120
+ </div>
121
+ `;
122
+ }
123
+ __addCountry() {
124
+ this.countries = { ...this.countries, [this.country]: '*' };
125
+ this.country = '';
126
+ this.dispatchEvent(new CustomEvent('update:countries'));
127
+ }
128
+ }
129
+ //# 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=\"h-m flex items-center rounded transition-colors border border-contrast-10 hover-border-contrast-40 focus-within-ring-1 focus-within-ring-primary-50 focus-within-border-primary-50\"\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 @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}\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,20 @@
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
+ regions: string[];
14
+ region: string;
15
+ name: string;
16
+ code: string;
17
+ render(): TemplateResult;
18
+ private __addRegion;
19
+ }
20
+ export {};
@@ -0,0 +1,125 @@
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.regions = [];
12
+ this.region = '';
13
+ this.name = '';
14
+ this.code = '';
15
+ }
16
+ static get properties() {
17
+ return {
18
+ ...super.properties,
19
+ regions: { type: Array },
20
+ region: { type: String },
21
+ name: { type: String },
22
+ code: { type: String },
23
+ };
24
+ }
25
+ render() {
26
+ var _a, _b;
27
+ return html `
28
+ <div class="border border-contrast-10 rounded text-s">
29
+ <div class="h-m flex justify-between items-center border-b border-contrast-10">
30
+ <div class="ml-m">
31
+ <span>${this.name || this.code}</span>
32
+ ${this.name ? html `<span class="text-secondary">${this.code}</span>` : ''}
33
+ </div>
34
+
35
+ <button
36
+ class="mr-xs flex items-center justify-center rounded-full transition-colors hover-bg-error-10 hover-text-error focus-outline-none focus-ring-2 focus-ring-inset focus-ring-error-50"
37
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
38
+ @click=${() => this.dispatchEvent(new CustomEvent('delete'))}
39
+ >
40
+ <iron-icon icon="icons:close" class="icon-inline text-m"></iron-icon>
41
+ </button>
42
+ </div>
43
+
44
+ <div class="flex flex-wrap p-xs">
45
+ ${this.regions.map(region => {
46
+ var _a, _b;
47
+ const name = (_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values[region]) === null || _b === void 0 ? void 0 : _b.default;
48
+ const code = region;
49
+ return html `
50
+ <div
51
+ class="flex items-center border border-contrast-10 h-s m-xs"
52
+ style="border-radius: var(--lumo-size-s)"
53
+ >
54
+ <span class="mx-s">
55
+ <span>${name || code}</span>
56
+ ${name ? html `<span class="text-secondary">${code}</span>` : ''}
57
+ </span>
58
+
59
+ <button
60
+ class="flex items-center justify-center rounded-full transition-colors hover-bg-error-10 hover-text-error focus-outline-none focus-ring-2 focus-ring-inset focus-ring-error-50"
61
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
62
+ @click=${() => {
63
+ this.regions = this.regions.filter(value => value !== region);
64
+ this.dispatchEvent(new CustomEvent('update:regions'));
65
+ }}
66
+ >
67
+ <iron-icon icon="icons:close" class="icon-inline text-m"></iron-icon>
68
+ </button>
69
+ </div>
70
+ `;
71
+ })}
72
+
73
+ <div
74
+ class="h-s m-xs flex items-center transition-colors border border-contrast-10 hover-border-contrast-40 focus-within-ring-1 focus-within-ring-primary-50 focus-within-border-primary-50"
75
+ style="border-radius: var(--lumo-size-s)"
76
+ >
77
+ <input
78
+ placeholder=${this.t('add_region')}
79
+ class="bg-transparent appearance-none h-s text-s px-s focus-outline-none"
80
+ style="width: 8rem"
81
+ list="list"
82
+ .value=${this.region}
83
+ @keydown=${(evt) => {
84
+ if (evt.key === 'Enter' && this.region)
85
+ this.__addRegion();
86
+ }}
87
+ @input=${(evt) => {
88
+ const target = evt.currentTarget;
89
+ this.region = target.value;
90
+ }}
91
+ />
92
+
93
+ <button
94
+ style="width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)"
95
+ class=${classMap({
96
+ 'flex-shrink-0': true,
97
+ 'flex items-center justify-center rounded-full transition-colors': true,
98
+ 'bg-contrast-5 text-disabled cursor-default': !this.region,
99
+ 'bg-success-10 text-success cursor-pointer': !!this.region,
100
+ 'hover-bg-success hover-text-success-contrast': !!this.region,
101
+ 'focus-outline-none focus-ring-2 ring-inset ring-success-50': !!this.region,
102
+ })}
103
+ ?disabled=${!this.region}
104
+ @click=${this.__addRegion}
105
+ >
106
+ <iron-icon icon="icons:add" class="icon-inline text-m"></iron-icon>
107
+ </button>
108
+ </div>
109
+
110
+ <datalist id="list">
111
+ ${Object.values((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a.values) !== null && _b !== void 0 ? _b : {}).map(region => {
112
+ return html `<option value=${region.code}>${region.default}</option>`;
113
+ })}
114
+ </datalist>
115
+ </div>
116
+ </div>
117
+ `;
118
+ }
119
+ __addRegion() {
120
+ this.regions = [...new Set([...this.regions, this.region])];
121
+ this.region = '';
122
+ this.dispatchEvent(new CustomEvent('update:regions'));
123
+ }
124
+ }
125
+ //# sourceMappingURL=CountryCard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CountryCard.js","sourceRoot":"","sources":["../../../../src/elements/public/TemplateConfigForm/CountryCard.ts"],"names":[],"mappings":"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","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 regions: { type: Array },\n region: { type: String },\n name: { type: String },\n code: { type: String },\n };\n }\n\n regions: string[] = [];\n\n region = '';\n\n name = '';\n\n code = '';\n\n render(): TemplateResult {\n return html`\n <div class=\"border border-contrast-10 rounded text-s\">\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=\"mr-xs flex items-center justify-center rounded-full transition-colors hover-bg-error-10 hover-text-error focus-outline-none focus-ring-2 focus-ring-inset focus-ring-error-50\"\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\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=\"flex items-center justify-center rounded-full transition-colors hover-bg-error-10 hover-text-error focus-outline-none focus-ring-2 focus-ring-inset focus-ring-error-50\"\n style=\"width: calc(var(--lumo-size-s) - 2px); height: calc(var(--lumo-size-s) - 2px)\"\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 class=\"h-s m-xs flex items-center transition-colors border border-contrast-10 hover-border-contrast-40 focus-within-ring-1 focus-within-ring-primary-50 focus-within-border-primary-50\"\n style=\"border-radius: var(--lumo-size-s)\"\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 @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,34 @@
1
+ import { Data } 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
+ export declare class TemplateConfigForm extends Base<Data> {
12
+ static get scopedElements(): ScopedElementsMap;
13
+ static get properties(): PropertyDeclarations;
14
+ countries: string;
15
+ regions: string;
16
+ private __addHiddenFieldInputValue;
17
+ render(): TemplateResult;
18
+ private __renderCartType;
19
+ private __renderFoxycomplete;
20
+ private __renderLocations;
21
+ private __renderHiddenFields;
22
+ private __renderCards;
23
+ private __renderCheckoutType;
24
+ private __renderConsent;
25
+ private __renderFields;
26
+ private __renderGoogleAnalytics;
27
+ private __renderSegmentIo;
28
+ private __renderTroubleshooting;
29
+ private __renderCustomConfig;
30
+ private __renderHeader;
31
+ private __renderCustomFields;
32
+ private __renderFooter;
33
+ }
34
+ export {};