@foxy.io/elements 1.16.0-beta.6 → 1.16.0-beta.7

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 (229) hide show
  1. package/dist/cdn/foxy-access-recovery-form.js +1 -1
  2. package/dist/cdn/foxy-address-card.js +1 -1
  3. package/dist/cdn/foxy-address-form.js +1 -1
  4. package/dist/cdn/foxy-api-browser.js +5 -0
  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-copy-to-clipboard.js +1 -1
  12. package/dist/cdn/foxy-coupon-card.js +1 -1
  13. package/dist/cdn/foxy-coupon-code-form.js +1 -1
  14. package/dist/cdn/foxy-coupon-codes-form.js +1 -1
  15. package/dist/cdn/foxy-coupon-detail-card.js +1 -1
  16. package/dist/cdn/foxy-coupon-form.js +1 -1
  17. package/dist/cdn/foxy-custom-field-card.js +1 -1
  18. package/dist/cdn/foxy-custom-field-form.js +1 -1
  19. package/dist/cdn/foxy-customer-api.js +1 -1
  20. package/dist/cdn/foxy-customer-card.js +1 -1
  21. package/dist/cdn/foxy-customer-form.js +1 -1
  22. package/dist/cdn/foxy-customer-portal-settings.js +1 -1
  23. package/dist/cdn/foxy-customer-portal.js +1 -1
  24. package/dist/cdn/foxy-customer.js +1 -1
  25. package/dist/cdn/foxy-customers-table.js +1 -1
  26. package/dist/cdn/foxy-discount-builder.js +1 -1
  27. package/dist/cdn/foxy-discount-card.js +1 -1
  28. package/dist/cdn/foxy-discount-detail-card.js +1 -1
  29. package/dist/cdn/foxy-donation.js +1 -1
  30. package/dist/cdn/foxy-email-template-form.js +1 -1
  31. package/dist/cdn/foxy-error-entry-card.js +1 -1
  32. package/dist/cdn/foxy-form-dialog.js +1 -1
  33. package/dist/cdn/foxy-generate-codes-form.js +1 -1
  34. package/dist/cdn/foxy-gift-card-card.js +1 -1
  35. package/dist/cdn/foxy-gift-card-code-form.js +1 -1
  36. package/dist/cdn/foxy-gift-card-codes-form.js +1 -1
  37. package/dist/cdn/foxy-gift-card-form.js +1 -1
  38. package/dist/cdn/foxy-i18n.js +1 -1
  39. package/dist/cdn/foxy-item-card.js +1 -1
  40. package/dist/cdn/foxy-item-form.js +1 -1
  41. package/dist/cdn/foxy-item-option-card.js +1 -1
  42. package/dist/cdn/foxy-item-option-form.js +1 -1
  43. package/dist/cdn/foxy-items-form.js +1 -1
  44. package/dist/cdn/foxy-nucleon-element.js +1 -1
  45. package/dist/cdn/foxy-pagination.js +1 -1
  46. package/dist/cdn/foxy-payment-card.js +1 -1
  47. package/dist/cdn/foxy-payment-method-card.js +1 -1
  48. package/dist/cdn/foxy-query-builder.js +1 -1
  49. package/dist/cdn/foxy-report-form.js +1 -1
  50. package/dist/cdn/foxy-reports-table.js +1 -1
  51. package/dist/cdn/foxy-shipment-card.js +2 -2
  52. package/dist/cdn/foxy-sign-in-form.js +1 -1
  53. package/dist/cdn/foxy-spinner.js +1 -1
  54. package/dist/cdn/foxy-subscription-card.js +1 -1
  55. package/dist/cdn/foxy-subscription-form.js +1 -1
  56. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  57. package/dist/cdn/foxy-swipe-actions.js +1 -1
  58. package/dist/cdn/foxy-table.js +1 -1
  59. package/dist/cdn/foxy-tax-card.js +1 -1
  60. package/dist/cdn/foxy-tax-form.js +1 -1
  61. package/dist/cdn/foxy-template-config-form.js +1 -1
  62. package/dist/cdn/foxy-template-form.js +1 -1
  63. package/dist/cdn/foxy-transaction-card.js +1 -1
  64. package/dist/cdn/foxy-transaction.js +2 -2
  65. package/dist/cdn/foxy-transactions-table.js +1 -1
  66. package/dist/cdn/foxy-user-form.js +1 -1
  67. package/dist/cdn/foxy-users-table.js +1 -1
  68. package/dist/cdn/foxy-webhook-card.js +1 -1
  69. package/dist/cdn/foxy-webhook-form.js +7 -7
  70. package/dist/cdn/foxy-webhook-log-card.js +1 -1
  71. package/dist/cdn/foxy-webhook-status-card.js +1 -1
  72. package/dist/cdn/shared-01a36c73.js +1 -0
  73. package/dist/cdn/{shared-16b54a16.js → shared-079141d8.js} +1 -1
  74. package/dist/cdn/{shared-e0e3bdc1.js → shared-0c468500.js} +1 -1
  75. package/dist/cdn/{shared-99065f2a.js → shared-0eb966c5.js} +1 -1
  76. package/dist/cdn/{shared-dd0fd816.js → shared-13a60e89.js} +1 -1
  77. package/dist/cdn/{shared-803a0366.js → shared-15e064b7.js} +1 -1
  78. package/dist/cdn/{shared-db34c00a.js → shared-198e7e30.js} +1 -1
  79. package/dist/cdn/{shared-0af1128f.js → shared-209bcce9.js} +1 -1
  80. package/dist/cdn/{shared-f3b35364.js → shared-22ba9566.js} +1 -1
  81. package/dist/cdn/{shared-ea0ac28c.js → shared-242babd5.js} +5 -5
  82. package/dist/cdn/{shared-1b064836.js → shared-25ef9e09.js} +1 -1
  83. package/dist/cdn/{shared-b65bb8ec.js → shared-3641bc33.js} +1 -1
  84. package/dist/cdn/{shared-9ad10520.js → shared-3aaa2bd1.js} +1 -1
  85. package/dist/cdn/{shared-30a41bea.js → shared-3f1f5801.js} +1 -1
  86. package/dist/cdn/{shared-2bb49907.js → shared-40315eea.js} +1 -1
  87. package/dist/cdn/{shared-96df3c85.js → shared-40c5712e.js} +1 -1
  88. package/dist/cdn/shared-567c8c48.js +1 -0
  89. package/dist/cdn/{shared-8f7f868c.js → shared-572bfe87.js} +1 -1
  90. package/dist/cdn/{shared-06014421.js → shared-58a9174f.js} +1 -1
  91. package/dist/cdn/{shared-28f78e36.js → shared-6366d131.js} +1 -1
  92. package/dist/cdn/{shared-0f2e2799.js → shared-64a2a826.js} +1 -1
  93. package/dist/cdn/{shared-3026cee0.js → shared-6eb57269.js} +1 -1
  94. package/dist/cdn/{shared-c76687b7.js → shared-741c109e.js} +1 -1
  95. package/dist/cdn/{shared-5f934d4e.js → shared-78f0bdad.js} +1 -1
  96. package/dist/cdn/shared-801b74d4.js +1 -0
  97. package/dist/cdn/{shared-eeecd876.js → shared-8be45bd7.js} +1 -1
  98. package/dist/cdn/{shared-d33bf73b.js → shared-8e973f80.js} +1 -1
  99. package/dist/cdn/{shared-a89fd2f0.js → shared-9418c6bb.js} +1 -1
  100. package/dist/cdn/{shared-3138e990.js → shared-9509bb93.js} +1 -1
  101. package/dist/cdn/shared-964c9ca9.js +1 -0
  102. package/dist/cdn/{shared-f3655f42.js → shared-968add7f.js} +1 -1
  103. package/dist/cdn/{shared-d3bf9ac0.js → shared-9803aa7c.js} +2 -2
  104. package/dist/cdn/{shared-11c2efc8.js → shared-99940888.js} +1 -1
  105. package/dist/cdn/{shared-dc545318.js → shared-9bd21899.js} +1 -1
  106. package/dist/cdn/{shared-9a91c68f.js → shared-9ce24b40.js} +1 -1
  107. package/dist/cdn/{shared-d519a301.js → shared-a0c6a159.js} +2 -2
  108. package/dist/cdn/{shared-eba18a6f.js → shared-a13bbf00.js} +1 -1
  109. package/dist/cdn/{shared-634813cb.js → shared-a1fb450b.js} +1 -1
  110. package/dist/cdn/{shared-bcfaeb2c.js → shared-a740808f.js} +1 -1
  111. package/dist/cdn/{shared-6b4564c6.js → shared-a7facb5b.js} +3 -3
  112. package/dist/cdn/{shared-6c9541a9.js → shared-a95d3bdd.js} +1 -1
  113. package/dist/cdn/{shared-6e80f6b9.js → shared-b31902a6.js} +2 -2
  114. package/dist/cdn/{shared-bebc774a.js → shared-bd0a55e6.js} +1 -1
  115. package/dist/cdn/{shared-0cab3007.js → shared-c0c55e07.js} +1 -1
  116. package/dist/cdn/{shared-8d8d637f.js → shared-c65ae0ed.js} +3 -3
  117. package/dist/cdn/{shared-7f33a83a.js → shared-dc73b9a5.js} +1 -1
  118. package/dist/cdn/shared-e0437bb4.js +1 -0
  119. package/dist/cdn/{shared-0479553e.js → shared-e1c1e8e2.js} +1 -1
  120. package/dist/cdn/{shared-65f1f0a5.js → shared-e5e7d3bd.js} +1 -1
  121. package/dist/cdn/{shared-4c35a2b7.js → shared-ef9fc547.js} +1 -1
  122. package/dist/cdn/{shared-012b606d.js → shared-f046baf7.js} +3 -3
  123. package/dist/cdn/{shared-e6f3e9f0.js → shared-f9f9ed5b.js} +1 -1
  124. package/dist/cdn/{shared-180ca311.js → shared-fd1913ad.js} +7 -7
  125. package/dist/cdn/translations/api-browser/en.json +22 -0
  126. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.d.ts +30 -0
  127. package/dist/elements/internal/{InternalCollectionCard/InternalCollectionCard.js → InternalAsyncDetailsControl/InternalAsyncDetailsControl.js} +57 -45
  128. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.js.map +1 -0
  129. package/dist/elements/internal/InternalAsyncDetailsControl/index.d.ts +7 -0
  130. package/dist/elements/internal/InternalAsyncDetailsControl/index.js +9 -0
  131. package/dist/elements/internal/InternalAsyncDetailsControl/index.js.map +1 -0
  132. package/dist/elements/internal/{InternalDetailsControl/InternalDetailsControl.d.ts → InternalDetails/InternalDetails.d.ts} +3 -3
  133. package/dist/elements/internal/{InternalDetailsControl/InternalDetailsControl.js → InternalDetails/InternalDetails.js} +3 -3
  134. package/dist/elements/internal/InternalDetails/InternalDetails.js.map +1 -0
  135. package/dist/elements/internal/{InternalDetailsControl → InternalDetails}/index.d.ts +2 -2
  136. package/dist/elements/internal/InternalDetails/index.js +8 -0
  137. package/dist/elements/internal/InternalDetails/index.js.map +1 -0
  138. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.d.ts +10 -4
  139. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js +9 -1
  140. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js.map +1 -1
  141. package/dist/elements/internal/InternalRadioGroupControl/types.d.ts +6 -0
  142. package/dist/elements/internal/InternalRadioGroupControl/types.js +2 -0
  143. package/dist/elements/internal/InternalRadioGroupControl/types.js.map +1 -0
  144. package/dist/elements/public/ApiBrowser/ApiBrowser.d.ts +23 -0
  145. package/dist/elements/public/ApiBrowser/ApiBrowser.js +204 -0
  146. package/dist/elements/public/ApiBrowser/ApiBrowser.js.map +1 -0
  147. package/dist/elements/public/ApiBrowser/index.d.ts +9 -0
  148. package/dist/elements/public/ApiBrowser/index.js +11 -0
  149. package/dist/elements/public/ApiBrowser/index.js.map +1 -0
  150. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.d.ts +25 -0
  151. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js +276 -0
  152. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js.map +1 -0
  153. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.d.ts +8 -0
  154. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js +10 -0
  155. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js.map +1 -0
  156. package/dist/elements/public/ApiBrowser/types.d.ts +10 -0
  157. package/dist/elements/public/ApiBrowser/types.js +2 -0
  158. package/dist/elements/public/ApiBrowser/types.js.map +1 -0
  159. package/dist/elements/public/ItemForm/ItemForm.js +8 -8
  160. package/dist/elements/public/ItemForm/ItemForm.js.map +1 -1
  161. package/dist/elements/public/ItemForm/index.d.ts +1 -1
  162. package/dist/elements/public/ItemForm/index.js +1 -1
  163. package/dist/elements/public/ItemForm/index.js.map +1 -1
  164. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js +2 -2
  165. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js.map +1 -1
  166. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.d.ts +1 -1
  167. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js +1 -1
  168. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js.map +1 -1
  169. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js +2 -2
  170. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js.map +1 -1
  171. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.d.ts +1 -1
  172. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js +1 -1
  173. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js.map +1 -1
  174. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js +2 -2
  175. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js.map +1 -1
  176. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.d.ts +1 -1
  177. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.js +1 -1
  178. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.js.map +1 -1
  179. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js +2 -2
  180. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js.map +1 -1
  181. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.d.ts +1 -1
  182. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js +1 -1
  183. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js.map +1 -1
  184. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js +2 -2
  185. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js.map +1 -1
  186. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.d.ts +1 -1
  187. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js +1 -1
  188. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js.map +1 -1
  189. package/dist/elements/public/ShipmentCard/ShipmentCard.js +2 -2
  190. package/dist/elements/public/ShipmentCard/ShipmentCard.js.map +1 -1
  191. package/dist/elements/public/ShipmentCard/index.d.ts +1 -1
  192. package/dist/elements/public/ShipmentCard/index.js +1 -1
  193. package/dist/elements/public/ShipmentCard/index.js.map +1 -1
  194. package/dist/elements/public/Transaction/Transaction.js +12 -12
  195. package/dist/elements/public/Transaction/Transaction.js.map +1 -1
  196. package/dist/elements/public/Transaction/index.d.ts +1 -1
  197. package/dist/elements/public/Transaction/index.js +1 -1
  198. package/dist/elements/public/Transaction/index.js.map +1 -1
  199. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js +2 -2
  200. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js.map +1 -1
  201. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.d.ts +1 -1
  202. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.js +1 -1
  203. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.js.map +1 -1
  204. package/dist/elements/public/WebhookForm/WebhookForm.js +4 -4
  205. package/dist/elements/public/WebhookForm/WebhookForm.js.map +1 -1
  206. package/dist/elements/public/WebhookForm/index.d.ts +1 -1
  207. package/dist/elements/public/WebhookForm/index.js +1 -1
  208. package/dist/elements/public/WebhookForm/index.js.map +1 -1
  209. package/dist/elements/public/index.d.ts +1 -0
  210. package/dist/elements/public/index.defined.d.ts +1 -0
  211. package/dist/elements/public/index.defined.js +1 -0
  212. package/dist/elements/public/index.defined.js.map +1 -1
  213. package/dist/elements/public/index.js +1 -0
  214. package/dist/elements/public/index.js.map +1 -1
  215. package/dist/mixins/themeable.js +192 -64
  216. package/dist/mixins/themeable.js.map +1 -1
  217. package/package.json +1 -1
  218. package/dist/cdn/shared-9d4835ed.js +0 -1
  219. package/dist/cdn/shared-dcb80bcf.js +0 -1
  220. package/dist/cdn/shared-dd43ab46.js +0 -1
  221. package/dist/cdn/shared-fe347acc.js +0 -1
  222. package/dist/elements/internal/InternalCollectionCard/InternalCollectionCard.d.ts +0 -13
  223. package/dist/elements/internal/InternalCollectionCard/InternalCollectionCard.js.map +0 -1
  224. package/dist/elements/internal/InternalCollectionCard/index.d.ts +0 -7
  225. package/dist/elements/internal/InternalCollectionCard/index.js +0 -9
  226. package/dist/elements/internal/InternalCollectionCard/index.js.map +0 -1
  227. package/dist/elements/internal/InternalDetailsControl/InternalDetailsControl.js.map +0 -1
  228. package/dist/elements/internal/InternalDetailsControl/index.js +0 -8
  229. package/dist/elements/internal/InternalDetailsControl/index.js.map +0 -1
@@ -0,0 +1,204 @@
1
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
2
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
3
+ import { NucleonElement } from "../NucleonElement/NucleonElement.js";
4
+ import { html } from 'lit-element';
5
+ const NS = 'api-browser';
6
+ const Base = ThemeableMixin(TranslatableMixin(NucleonElement, NS));
7
+ export class ApiBrowser extends Base {
8
+ constructor() {
9
+ super(...arguments);
10
+ this.home = null;
11
+ this.__history = [];
12
+ this.__renderItem = ({ href, html }) => {
13
+ if (!href)
14
+ return html ``;
15
+ return html `
16
+ <foxy-internal-api-browser-resource-form infer="" href=${href}>
17
+ </foxy-internal-api-browser-resource-form>
18
+ `;
19
+ };
20
+ this.__handleExistingResourceFetch = (evt) => {
21
+ if (evt.request.method === 'DELETE') {
22
+ evt.preventDefault();
23
+ evt.respondWith(new ApiBrowser.API(this).fetch(evt.request).then(response => {
24
+ if (response.ok) {
25
+ if (this.__canGoBack) {
26
+ this.__goBack();
27
+ }
28
+ else if (this.__canGoHome) {
29
+ this.__goHome();
30
+ }
31
+ else {
32
+ this.parent = '';
33
+ this.href = '';
34
+ }
35
+ }
36
+ return response;
37
+ }));
38
+ }
39
+ };
40
+ }
41
+ static get properties() {
42
+ return {
43
+ ...super.properties,
44
+ __history: { attribute: false },
45
+ home: { type: String },
46
+ };
47
+ }
48
+ render() {
49
+ var _a;
50
+ return html `
51
+ <div class="space-y-m">
52
+ <div class="flex items-center gap-s flex-wrap-reverse">
53
+ <vaadin-button
54
+ title=${this.t('go_back')}
55
+ theme="icon contrast"
56
+ class="p-0"
57
+ ?disabled=${!this.__canGoBack}
58
+ @click=${() => this.__goBack()}
59
+ >
60
+ <iron-icon class="icon-inline text-m" icon="icons:arrow-back"></iron-icon>
61
+ </vaadin-button>
62
+
63
+ <vaadin-button
64
+ title=${this.t('go_home')}
65
+ theme="icon contrast"
66
+ class="p-0"
67
+ ?disabled=${!this.__canGoHome}
68
+ @click=${() => this.__goHome()}
69
+ >
70
+ <iron-icon class="icon-inline text-m" icon="icons:home"></iron-icon>
71
+ </vaadin-button>
72
+
73
+ <vaadin-text-field
74
+ placeholder="https://api.foxy.io/stores/0"
75
+ class="flex-1"
76
+ .value=${this.href || this.parent}
77
+ @input=${(evt) => {
78
+ const field = evt.currentTarget;
79
+ this[this.href ? 'href' : 'parent'] = field.value;
80
+ }}
81
+ >
82
+ </vaadin-text-field>
83
+
84
+ <vaadin-button
85
+ title=${this.t('refresh')}
86
+ theme="icon contrast"
87
+ class="p-0"
88
+ ?disabled=${this.in('busy')}
89
+ @click=${() => this.refresh()}
90
+ >
91
+ <iron-icon class="icon-inline text-m" icon="icons:refresh"></iron-icon>
92
+ </vaadin-button>
93
+
94
+ <div class="grid grid-cols-2">
95
+ <vaadin-button
96
+ theme=${this.href ? 'contrast primary' : 'contrast'}
97
+ class="rounded-r-none p-0"
98
+ ?disabled=${this.__mode === 'get'}
99
+ @click=${() => (this.__mode = 'get')}
100
+ >
101
+ GET
102
+ </vaadin-button>
103
+
104
+ <vaadin-button
105
+ theme=${this.href ? 'contrast' : 'contrast primary'}
106
+ class="rounded-l-none p-0"
107
+ ?disabled=${this.__mode === 'post'}
108
+ @click=${() => (this.__mode = 'post')}
109
+ >
110
+ POST
111
+ </vaadin-button>
112
+ </div>
113
+ </div>
114
+
115
+ <div
116
+ @navigate:get=${(evt) => {
117
+ evt.stopPropagation();
118
+ this.__history.push({ href: this.href, parent: this.parent });
119
+ this.parent = '';
120
+ this.href = evt.detail;
121
+ }}
122
+ @navigate:post=${(evt) => {
123
+ evt.stopPropagation();
124
+ this.__history.push({ href: this.href, parent: this.parent });
125
+ this.parent = evt.detail;
126
+ this.href = '';
127
+ }}
128
+ >
129
+ ${this.href
130
+ ? html `
131
+ ${((_a = this.data) === null || _a === void 0 ? void 0 : _a._links.first) ? html `
132
+ <foxy-pagination first=${this.href} infer="">
133
+ <foxy-collection-page
134
+ class="block space-y-m mb-m"
135
+ infer=""
136
+ .item=${this.__renderItem}
137
+ >
138
+ </foxy-collection-page>
139
+ </foxy-pagination>
140
+ `
141
+ : html `
142
+ <foxy-internal-api-browser-resource-form
143
+ infer=""
144
+ href=${this.href}
145
+ open
146
+ @fetch=${this.__handleExistingResourceFetch}
147
+ >
148
+ </foxy-internal-api-browser-resource-form>
149
+ `}
150
+ `
151
+ : html `
152
+ <foxy-internal-api-browser-resource-form
153
+ infer=""
154
+ parent=${this.parent}
155
+ open
156
+ @update=${(evt) => {
157
+ const form = evt.currentTarget;
158
+ if (form.in({ idle: 'snapshot' })) {
159
+ this.href = form.data._links.self.href;
160
+ this.parent = '';
161
+ }
162
+ }}
163
+ >
164
+ </foxy-internal-api-browser-resource-form>
165
+ `}
166
+ </div>
167
+ </div>
168
+ `;
169
+ }
170
+ get __canGoBack() {
171
+ return this.__history.length > 0;
172
+ }
173
+ get __canGoHome() {
174
+ return this.href !== this.home;
175
+ }
176
+ get __mode() {
177
+ return this.href ? 'get' : 'post';
178
+ }
179
+ set __mode(newValue) {
180
+ if (newValue === 'get') {
181
+ this.href = this.parent;
182
+ this.parent = '';
183
+ }
184
+ else {
185
+ this.parent = this.href;
186
+ this.href = '';
187
+ }
188
+ }
189
+ __goBack() {
190
+ var _a, _b;
191
+ const index = this.__history.length - 1;
192
+ const entry = this.__history[index];
193
+ this.parent = (_a = entry === null || entry === void 0 ? void 0 : entry.parent) !== null && _a !== void 0 ? _a : '';
194
+ this.href = (_b = entry === null || entry === void 0 ? void 0 : entry.href) !== null && _b !== void 0 ? _b : '';
195
+ this.__history = this.__history.slice(0, index);
196
+ }
197
+ __goHome() {
198
+ var _a;
199
+ this.__history = [];
200
+ this.parent = '';
201
+ this.href = (_a = this.home) !== null && _a !== void 0 ? _a : '';
202
+ }
203
+ }
204
+ //# sourceMappingURL=ApiBrowser.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiBrowser.js","sourceRoot":"","sources":["../../../../src/elements/public/ApiBrowser/ApiBrowser.ts"],"names":[],"mappings":"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","sourcesContent":["import type { PropertyDeclarations, TemplateResult } from 'lit-element';\nimport type { InternalApiBrowserResourceForm } from './internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm';\nimport type { ItemRendererContext } from '../CollectionPage/types';\nimport type { FetchEvent } from '../NucleonElement/FetchEvent';\nimport type { Data } from './types';\n\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { TextFieldElement } from '@vaadin/vaadin-text-field';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { html } from 'lit-element';\n\nconst NS = 'api-browser';\nconst Base = ThemeableMixin(TranslatableMixin(NucleonElement, NS));\n\nexport class ApiBrowser extends Base<Data> {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n __history: { attribute: false },\n home: { type: String },\n };\n }\n\n home: string | null = null;\n\n private __history: { href: string; parent: string }[] = [];\n\n private __renderItem = ({ href, html }: ItemRendererContext<Data>) => {\n if (!href) return html``;\n return html`\n <foxy-internal-api-browser-resource-form infer=\"\" href=${href}>\n </foxy-internal-api-browser-resource-form>\n `;\n };\n\n private __handleExistingResourceFetch = (evt: FetchEvent) => {\n if (evt.request.method === 'DELETE') {\n evt.preventDefault();\n evt.respondWith(\n new ApiBrowser.API(this).fetch(evt.request).then(response => {\n if (response.ok) {\n if (this.__canGoBack) {\n this.__goBack();\n } else if (this.__canGoHome) {\n this.__goHome();\n } else {\n this.parent = '';\n this.href = '';\n }\n }\n\n return response;\n })\n );\n }\n };\n\n render(): TemplateResult {\n return html`\n <div class=\"space-y-m\">\n <div class=\"flex items-center gap-s flex-wrap-reverse\">\n <vaadin-button\n title=${this.t('go_back')}\n theme=\"icon contrast\"\n class=\"p-0\"\n ?disabled=${!this.__canGoBack}\n @click=${() => this.__goBack()}\n >\n <iron-icon class=\"icon-inline text-m\" icon=\"icons:arrow-back\"></iron-icon>\n </vaadin-button>\n\n <vaadin-button\n title=${this.t('go_home')}\n theme=\"icon contrast\"\n class=\"p-0\"\n ?disabled=${!this.__canGoHome}\n @click=${() => this.__goHome()}\n >\n <iron-icon class=\"icon-inline text-m\" icon=\"icons:home\"></iron-icon>\n </vaadin-button>\n\n <vaadin-text-field\n placeholder=\"https://api.foxy.io/stores/0\"\n class=\"flex-1\"\n .value=${this.href || this.parent}\n @input=${(evt: CustomEvent) => {\n const field = evt.currentTarget as TextFieldElement;\n this[this.href ? 'href' : 'parent'] = field.value;\n }}\n >\n </vaadin-text-field>\n\n <vaadin-button\n title=${this.t('refresh')}\n theme=\"icon contrast\"\n class=\"p-0\"\n ?disabled=${this.in('busy')}\n @click=${() => this.refresh()}\n >\n <iron-icon class=\"icon-inline text-m\" icon=\"icons:refresh\"></iron-icon>\n </vaadin-button>\n\n <div class=\"grid grid-cols-2\">\n <vaadin-button\n theme=${this.href ? 'contrast primary' : 'contrast'}\n class=\"rounded-r-none p-0\"\n ?disabled=${this.__mode === 'get'}\n @click=${() => (this.__mode = 'get')}\n >\n GET\n </vaadin-button>\n\n <vaadin-button\n theme=${this.href ? 'contrast' : 'contrast primary'}\n class=\"rounded-l-none p-0\"\n ?disabled=${this.__mode === 'post'}\n @click=${() => (this.__mode = 'post')}\n >\n POST\n </vaadin-button>\n </div>\n </div>\n\n <div\n @navigate:get=${(evt: CustomEvent<string>) => {\n evt.stopPropagation();\n this.__history.push({ href: this.href, parent: this.parent });\n this.parent = '';\n this.href = evt.detail;\n }}\n @navigate:post=${(evt: CustomEvent<string>) => {\n evt.stopPropagation();\n this.__history.push({ href: this.href, parent: this.parent });\n this.parent = evt.detail;\n this.href = '';\n }}\n >\n ${this.href\n ? html`\n ${this.data?._links.first\n ? html`\n <foxy-pagination first=${this.href} infer=\"\">\n <foxy-collection-page\n class=\"block space-y-m mb-m\"\n infer=\"\"\n .item=${this.__renderItem as any}\n >\n </foxy-collection-page>\n </foxy-pagination>\n `\n : html`\n <foxy-internal-api-browser-resource-form\n infer=\"\"\n href=${this.href}\n open\n @fetch=${this.__handleExistingResourceFetch}\n >\n </foxy-internal-api-browser-resource-form>\n `}\n `\n : html`\n <foxy-internal-api-browser-resource-form\n infer=\"\"\n parent=${this.parent}\n open\n @update=${(evt: CustomEvent) => {\n const form = evt.currentTarget as InternalApiBrowserResourceForm;\n if (form.in({ idle: 'snapshot' })) {\n this.href = form.data._links.self.href;\n this.parent = '';\n }\n }}\n >\n </foxy-internal-api-browser-resource-form>\n `}\n </div>\n </div>\n `;\n }\n\n private get __canGoBack() {\n return this.__history.length > 0;\n }\n\n private get __canGoHome() {\n return this.href !== this.home;\n }\n\n private get __mode() {\n return this.href ? 'get' : 'post';\n }\n\n private set __mode(newValue: 'get' | 'post') {\n if (newValue === 'get') {\n this.href = this.parent;\n this.parent = '';\n } else {\n this.parent = this.href;\n this.href = '';\n }\n }\n\n private __goBack() {\n const index = this.__history.length - 1;\n const entry = this.__history[index];\n\n this.parent = entry?.parent ?? '';\n this.href = entry?.href ?? '';\n this.__history = this.__history.slice(0, index);\n }\n\n private __goHome() {\n this.__history = [];\n this.parent = '';\n this.href = this.home ?? '';\n }\n}\n"]}
@@ -0,0 +1,9 @@
1
+ import '@vaadin/vaadin-text-field';
2
+ import '@vaadin/vaadin-button';
3
+ import '@polymer/iron-icons';
4
+ import '@polymer/iron-icon';
5
+ import '../CollectionPage/index';
6
+ import '../Pagination/index';
7
+ import './internal/InternalApiBrowserResourceForm/index';
8
+ import { ApiBrowser } from './ApiBrowser';
9
+ export { ApiBrowser };
@@ -0,0 +1,11 @@
1
+ import '@vaadin/vaadin-text-field';
2
+ import '@vaadin/vaadin-button';
3
+ import '@polymer/iron-icons';
4
+ import '@polymer/iron-icon';
5
+ import "../CollectionPage/index.js";
6
+ import "../Pagination/index.js";
7
+ import "./internal/InternalApiBrowserResourceForm/index.js";
8
+ import { ApiBrowser } from "./ApiBrowser.js";
9
+ customElements.define('foxy-api-browser', ApiBrowser);
10
+ export { ApiBrowser };
11
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/public/ApiBrowser/index.ts"],"names":[],"mappings":"AAAA,OAAO,2BAA2B,CAAC;AACnC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,oBAAoB,CAAC;AAE5B,oCAAiC;AACjC,gCAA6B;AAE7B,4DAAyD;AAEzD,OAAO,EAAE,UAAU,EAAE,wBAAqB;AAE1C,cAAc,CAAC,MAAM,CAAC,kBAAkB,EAAE,UAAU,CAAC,CAAC;AAEtD,OAAO,EAAE,UAAU,EAAE,CAAC","sourcesContent":["import '@vaadin/vaadin-text-field';\nimport '@vaadin/vaadin-button';\nimport '@polymer/iron-icons';\nimport '@polymer/iron-icon';\n\nimport '../CollectionPage/index';\nimport '../Pagination/index';\n\nimport './internal/InternalApiBrowserResourceForm/index';\n\nimport { ApiBrowser } from './ApiBrowser';\n\ncustomElements.define('foxy-api-browser', ApiBrowser);\n\nexport { ApiBrowser };\n"]}
@@ -0,0 +1,25 @@
1
+ import type { CSSResultArray, PropertyDeclarations } from 'lit-element';
2
+ import type { TemplateResult } from 'lit-html';
3
+ import type { NucleonV8N } from '../../../NucleonElement/types';
4
+ import type { Data } from '../../types';
5
+ import { InternalForm } from '../../../../internal/InternalForm/InternalForm';
6
+ declare const InternalApiBrowserResourceForm_base: typeof InternalForm & import("lit-element").Constructor<import("../../../../../mixins/translatable").TranslatableMixinHost> & {
7
+ defaultNS: string;
8
+ };
9
+ export declare class InternalApiBrowserResourceForm extends InternalApiBrowserResourceForm_base<Data> {
10
+ static get properties(): PropertyDeclarations;
11
+ static get styles(): CSSResultArray;
12
+ static get v8n(): NucleonV8N<any>;
13
+ open: boolean;
14
+ renderBody(): TemplateResult;
15
+ updated(changes: Map<keyof this, unknown>): void;
16
+ protected _fetch<TResult = any>(...args: Parameters<Window['fetch']>): Promise<TResult>;
17
+ private __setTextAreaHeight;
18
+ private __renderTitle;
19
+ private __renderForm;
20
+ private get __links();
21
+ private get __formAsString();
22
+ private set __formAsString(value);
23
+ private __renderLink;
24
+ }
25
+ export {};
@@ -0,0 +1,276 @@
1
+ import { TranslatableMixin } from "../../../../../mixins/translatable.js";
2
+ import { InternalForm } from "../../../../internal/InternalForm/InternalForm.js";
3
+ import { classMap } from "../../../../../utils/class-map.js";
4
+ import { html } from 'lit-html';
5
+ import { css } from 'lit-element';
6
+ const InvalidValueSymbol = Symbol();
7
+ const ValidValueSymbol = Symbol();
8
+ export class InternalApiBrowserResourceForm extends TranslatableMixin(InternalForm) {
9
+ constructor() {
10
+ super(...arguments);
11
+ this.open = false;
12
+ }
13
+ static get properties() {
14
+ return {
15
+ ...super.properties,
16
+ open: { type: Boolean },
17
+ };
18
+ }
19
+ static get styles() {
20
+ return [
21
+ ...super.styles,
22
+ css `.monospace{
23
+ font-family:monospace;
24
+ }
25
+
26
+ .resize-none{
27
+ resize:none;
28
+ }
29
+
30
+ .resource{
31
+ display:grid;
32
+ grid-template-columns:repeat(auto-fill, minmax(calc(18.75 * var(--lumo-space-m)), 1fr));
33
+ grid-gap:1px;
34
+ }
35
+
36
+ .resource > :first-child{
37
+ grid-column-start:1;
38
+ grid-column-end:-2;
39
+ }
40
+ `,
41
+ ];
42
+ }
43
+ static get v8n() {
44
+ return [
45
+ ...super.v8n,
46
+ v => (typeof v[InvalidValueSymbol] === 'string' ? 'invalid_json' : true),
47
+ ];
48
+ }
49
+ renderBody() {
50
+ return html `
51
+ <details
52
+ class="rounded-t-l rounded-b-l overflow-hidden border border-contrast-10"
53
+ ?open=${this.open}
54
+ @toggle=${(evt) => {
55
+ const details = evt.currentTarget;
56
+ this.open = details.open;
57
+ }}
58
+ >
59
+ <summary>
60
+ <div class="flex items-center space-x-s p-s pr-m bg-contrast-5">
61
+ <foxy-copy-to-clipboard infer="copy-to-clipboard" text=${this.href || this.parent}>
62
+ </foxy-copy-to-clipboard>
63
+
64
+ <span class="font-semibold truncate">${this.__renderTitle()}</span>
65
+ <span class="flex-1"></span>
66
+
67
+ ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: 'template' })
68
+ ? html `
69
+ <vaadin-button
70
+ theme="tertiary-inline success"
71
+ class="px-xs"
72
+ ?disabled=${this.errors.length > 0}
73
+ @click=${() => this.submit()}
74
+ >
75
+ <foxy-i18n infer="" key="submit"></foxy-i18n>
76
+ </vaadin-button>
77
+ `
78
+ : ''}
79
+ ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: { template: 'dirty' } })
80
+ ? html `
81
+ <vaadin-button
82
+ theme="tertiary-inline contrast"
83
+ class="px-xs"
84
+ @click=${() => this.undo()}
85
+ >
86
+ <foxy-i18n infer="" key="undo"></foxy-i18n>
87
+ </vaadin-button>
88
+ `
89
+ : ''}
90
+ ${this.in({ idle: 'snapshot' })
91
+ ? html `
92
+ <vaadin-button
93
+ theme="tertiary-inline error"
94
+ class="px-xs"
95
+ @click=${() => this.delete()}
96
+ >
97
+ <foxy-i18n infer="" key="delete"></foxy-i18n>
98
+ </vaadin-button>
99
+ `
100
+ : ''}
101
+ </div>
102
+ </summary>
103
+
104
+ ${this.open ? this.__renderForm() : ''}
105
+ </details>
106
+ `;
107
+ }
108
+ updated(changes) {
109
+ super.updated(changes);
110
+ this.__setTextAreaHeight();
111
+ }
112
+ async _fetch(...args) {
113
+ try {
114
+ const request = args[0] instanceof Request ? args[0] : new Request(...args);
115
+ if (request.method !== 'POST')
116
+ return await super._fetch(...args);
117
+ const body = this.form[ValidValueSymbol];
118
+ return await super._fetch(request.url, { method: 'POST', body });
119
+ }
120
+ catch (err) {
121
+ throw ['invalid_json'];
122
+ }
123
+ }
124
+ __setTextAreaHeight() {
125
+ const textarea = this.renderRoot.querySelector('textarea');
126
+ if (textarea) {
127
+ textarea.style.height = 'auto';
128
+ textarea.style.height = `${textarea.scrollHeight}px`;
129
+ textarea.style.overflowY = 'hidden';
130
+ }
131
+ }
132
+ __renderTitle() {
133
+ if (!this.href) {
134
+ return html `
135
+ <span class="text-tertiary">POST</span>
136
+ <span>${this.parent}</span>
137
+ `;
138
+ }
139
+ let pathname = '';
140
+ let identifier = '';
141
+ let search = '';
142
+ try {
143
+ const url = new URL(this.href);
144
+ pathname = url.pathname;
145
+ if (pathname.startsWith('/'))
146
+ pathname = pathname.substring(1);
147
+ const splitPathname = pathname.split('/');
148
+ pathname = splitPathname.slice(0, splitPathname.length - 1).join('/');
149
+ if (splitPathname.length > 1) {
150
+ pathname = `${pathname}/`;
151
+ identifier = splitPathname[splitPathname.length - 1];
152
+ }
153
+ search = url.search;
154
+ }
155
+ catch (_a) {
156
+ pathname = this.href;
157
+ }
158
+ return html `
159
+ ${[
160
+ html `<span>${pathname}</span>`,
161
+ html `<span class="text-primary">${identifier}</span>`,
162
+ html `<span class="text-tertiary">${search}</span>`,
163
+ ]}
164
+ `;
165
+ }
166
+ __renderForm() {
167
+ return html `
168
+ <div class="bg-base">
169
+ <div class="${this.data ? 'resource' : ''} border-t border-contrast-5 bg-contrast-10">
170
+ <div class="flex-1 flex bg-base">
171
+ <div class="monospace bg-contrast-5 leading-s text-s p-m text-tertiary text-right">
172
+ ${this.__formAsString.split('\n').map((_, index) => html `<div>${index + 1}</div>`)}
173
+ </div>
174
+
175
+ <textarea
176
+ class=${classMap({
177
+ 'whitespace-nowrap leading-s text-s focus-outline-none': true,
178
+ 'monospace resize-none p-m block w-full': true,
179
+ 'bg-error-10': this.errors.length > 0,
180
+ 'bg-base': this.errors.length === 0,
181
+ })}
182
+ .value=${this.__formAsString}
183
+ @input=${(evt) => {
184
+ const textarea = evt.currentTarget;
185
+ this.__formAsString = textarea.value;
186
+ }}
187
+ >
188
+ </textarea>
189
+ </div>
190
+
191
+ ${this.data
192
+ ? html `
193
+ <div class="bg-base">
194
+ <ul class="bg-contrast-5 p-xs h-full">
195
+ ${this.__links.map(([curie, link]) => this.__renderLink(curie, link.href, link.title))}
196
+ </ul>
197
+ </div>
198
+ `
199
+ : ''}
200
+ </div>
201
+ </div>
202
+ `;
203
+ }
204
+ get __links() {
205
+ var _a, _b;
206
+ return Object.entries((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a._links) !== null && _b !== void 0 ? _b : {}).filter(([curie, link]) => curie !== 'self' && !Array.isArray(link) && !link.templated);
207
+ }
208
+ get __formAsString() {
209
+ const form = this.form;
210
+ const validValue = form[ValidValueSymbol];
211
+ const invalidValue = form[InvalidValueSymbol];
212
+ if (typeof invalidValue === 'string')
213
+ return invalidValue;
214
+ if (typeof validValue === 'string')
215
+ return validValue;
216
+ return JSON.stringify(form, (key, value) => (key.startsWith('_') ? undefined : value), 2);
217
+ }
218
+ set __formAsString(newValue) {
219
+ this.undo();
220
+ try {
221
+ const parsedNewValue = JSON.parse(newValue);
222
+ if (typeof parsedNewValue === 'object')
223
+ this.edit(parsedNewValue);
224
+ this.edit({ [ValidValueSymbol]: newValue });
225
+ }
226
+ catch (_a) {
227
+ this.edit({ [InvalidValueSymbol]: newValue });
228
+ }
229
+ }
230
+ __renderLink(curie, href, title) {
231
+ return html `
232
+ <li class="m-xs rounded overflow-hidden transition-colors hover-bg-contrast-5">
233
+ <foxy-swipe-actions>
234
+ <button
235
+ class=${classMap({
236
+ 'rounded leading-none space-y-xs block text-left w-full py-s': true,
237
+ 'ring-inset ring-primary-50': true,
238
+ 'focus-outline-none focus-ring-2 ': true,
239
+ })}
240
+ @click=${() => {
241
+ const evt = new CustomEvent('navigate:get', { bubbles: true, detail: href });
242
+ this.dispatchEvent(evt);
243
+ }}
244
+ >
245
+ <div class="flex items-center">
246
+ <div class="flex-1 space-y-xs px-s min-w-0 text-s">
247
+ <div class="truncate font-semibold">${title || href}</div>
248
+ <div class="opacity-75 truncate">${curie}</div>
249
+ </div>
250
+
251
+ <iron-icon
252
+ class="icon-inline text-xl text-tertiary mr-s flex-shrink-0"
253
+ icon="icons:chevron-right"
254
+ >
255
+ </iron-icon>
256
+ </div>
257
+ </button>
258
+
259
+ <div slot="action" class="h-full flex">
260
+ <vaadin-button
261
+ theme="secondary success"
262
+ class="h-full rounded-none"
263
+ @click=${() => {
264
+ const evt = new CustomEvent('navigate:post', { bubbles: true, detail: href });
265
+ this.dispatchEvent(evt);
266
+ }}
267
+ >
268
+ POST
269
+ </vaadin-button>
270
+ </div>
271
+ </foxy-swipe-actions>
272
+ </li>
273
+ `;
274
+ }
275
+ }
276
+ //# sourceMappingURL=InternalApiBrowserResourceForm.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InternalApiBrowserResourceForm.js","sourceRoot":"","sources":["../../../../../../src/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CSSResultArray, PropertyDeclarations } from 'lit-element';\nimport type { TemplateResult } from 'lit-html';\nimport type { NucleonV8N } from '../../../NucleonElement/types';\nimport type { Data } from '../../types';\n\nimport { TranslatableMixin } from '../../../../../mixins/translatable';\nimport { InternalForm } from '../../../../internal/InternalForm/InternalForm';\nimport { classMap } from '../../../../../utils/class-map';\nimport { html } from 'lit-html';\nimport { css } from 'lit-element';\n\nconst InvalidValueSymbol = Symbol() as symbol;\nconst ValidValueSymbol = Symbol() as symbol;\n\nexport class InternalApiBrowserResourceForm extends TranslatableMixin(InternalForm)<Data> {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n open: { type: Boolean },\n };\n }\n\n static get styles(): CSSResultArray {\n return [\n ...super.styles,\n css`\n .monospace {\n font-family: monospace;\n }\n\n .resize-none {\n resize: none;\n }\n\n .resource {\n display: grid;\n grid-template-columns: repeat(auto-fill, minmax(calc(18.75 * var(--lumo-space-m)), 1fr));\n grid-gap: 1px;\n }\n\n .resource > :first-child {\n grid-column-start: 1;\n grid-column-end: -2;\n }\n `,\n ];\n }\n\n static get v8n(): NucleonV8N<any> {\n return [\n ...super.v8n,\n v => (typeof (v as any)[InvalidValueSymbol] === 'string' ? 'invalid_json' : true),\n ];\n }\n\n open = false;\n\n renderBody(): TemplateResult {\n return html`\n <details\n class=\"rounded-t-l rounded-b-l overflow-hidden border border-contrast-10\"\n ?open=${this.open}\n @toggle=${(evt: Event) => {\n const details = evt.currentTarget as HTMLDetailsElement;\n this.open = details.open;\n }}\n >\n <summary>\n <div class=\"flex items-center space-x-s p-s pr-m bg-contrast-5\">\n <foxy-copy-to-clipboard infer=\"copy-to-clipboard\" text=${this.href || this.parent}>\n </foxy-copy-to-clipboard>\n\n <span class=\"font-semibold truncate\">${this.__renderTitle()}</span>\n <span class=\"flex-1\"></span>\n\n ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: 'template' })\n ? html`\n <vaadin-button\n theme=\"tertiary-inline success\"\n class=\"px-xs\"\n ?disabled=${this.errors.length > 0}\n @click=${() => this.submit()}\n >\n <foxy-i18n infer=\"\" key=\"submit\"></foxy-i18n>\n </vaadin-button>\n `\n : ''}\n ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: { template: 'dirty' } })\n ? html`\n <vaadin-button\n theme=\"tertiary-inline contrast\"\n class=\"px-xs\"\n @click=${() => this.undo()}\n >\n <foxy-i18n infer=\"\" key=\"undo\"></foxy-i18n>\n </vaadin-button>\n `\n : ''}\n ${this.in({ idle: 'snapshot' })\n ? html`\n <vaadin-button\n theme=\"tertiary-inline error\"\n class=\"px-xs\"\n @click=${() => this.delete()}\n >\n <foxy-i18n infer=\"\" key=\"delete\"></foxy-i18n>\n </vaadin-button>\n `\n : ''}\n </div>\n </summary>\n\n ${this.open ? this.__renderForm() : ''}\n </details>\n `;\n }\n\n updated(changes: Map<keyof this, unknown>): void {\n super.updated(changes);\n this.__setTextAreaHeight();\n }\n\n protected async _fetch<TResult = any>(...args: Parameters<Window['fetch']>): Promise<TResult> {\n try {\n const request = args[0] instanceof Request ? args[0] : new Request(...args);\n if (request.method !== 'POST') return await super._fetch(...args);\n\n const body = (this.form as any)[ValidValueSymbol];\n return await super._fetch(request.url, { method: 'POST', body });\n } catch (err) {\n throw ['invalid_json'];\n }\n }\n\n private __setTextAreaHeight() {\n const textarea = this.renderRoot.querySelector<HTMLTextAreaElement>('textarea');\n\n if (textarea) {\n textarea.style.height = 'auto';\n textarea.style.height = `${textarea.scrollHeight}px`;\n textarea.style.overflowY = 'hidden';\n }\n }\n\n private __renderTitle() {\n if (!this.href) {\n return html`\n <span class=\"text-tertiary\">POST</span>\n <span>${this.parent}</span>\n `;\n }\n\n let pathname = '';\n let identifier = '';\n let search = '';\n\n try {\n const url = new URL(this.href);\n\n pathname = url.pathname;\n if (pathname.startsWith('/')) pathname = pathname.substring(1);\n\n const splitPathname = pathname.split('/');\n pathname = splitPathname.slice(0, splitPathname.length - 1).join('/');\n\n if (splitPathname.length > 1) {\n pathname = `${pathname}/`;\n identifier = splitPathname[splitPathname.length - 1];\n }\n\n search = url.search;\n } catch {\n pathname = this.href;\n }\n\n return html`\n ${[\n html`<span>${pathname}</span>`,\n html`<span class=\"text-primary\">${identifier}</span>`,\n html`<span class=\"text-tertiary\">${search}</span>`,\n ]}\n `;\n }\n\n private __renderForm() {\n return html`\n <div class=\"bg-base\">\n <div class=\"${this.data ? 'resource' : ''} border-t border-contrast-5 bg-contrast-10\">\n <div class=\"flex-1 flex bg-base\">\n <div class=\"monospace bg-contrast-5 leading-s text-s p-m text-tertiary text-right\">\n ${this.__formAsString.split('\\n').map((_, index) => html`<div>${index + 1}</div>`)}\n </div>\n\n <textarea\n class=${classMap({\n 'whitespace-nowrap leading-s text-s focus-outline-none': true,\n 'monospace resize-none p-m block w-full': true,\n 'bg-error-10': this.errors.length > 0,\n 'bg-base': this.errors.length === 0,\n })}\n .value=${this.__formAsString}\n @input=${(evt: InputEvent) => {\n const textarea = evt.currentTarget as HTMLTextAreaElement;\n this.__formAsString = textarea.value;\n }}\n >\n </textarea>\n </div>\n\n ${this.data\n ? html`\n <div class=\"bg-base\">\n <ul class=\"bg-contrast-5 p-xs h-full\">\n ${this.__links.map(([curie, link]) =>\n this.__renderLink(curie, link.href, link.title)\n )}\n </ul>\n </div>\n `\n : ''}\n </div>\n </div>\n `;\n }\n\n private get __links() {\n return Object.entries(this.data?._links ?? {}).filter(\n ([curie, link]) => curie !== 'self' && !Array.isArray(link) && !(link as any).templated\n );\n }\n\n private get __formAsString() {\n const form = this.form as any;\n const validValue = form[ValidValueSymbol];\n const invalidValue = form[InvalidValueSymbol];\n\n if (typeof invalidValue === 'string') return invalidValue;\n if (typeof validValue === 'string') return validValue;\n\n return JSON.stringify(form, (key, value) => (key.startsWith('_') ? undefined : value), 2);\n }\n\n private set __formAsString(newValue: string) {\n this.undo();\n\n try {\n const parsedNewValue = JSON.parse(newValue);\n if (typeof parsedNewValue === 'object') this.edit(parsedNewValue);\n this.edit({ [ValidValueSymbol]: newValue });\n } catch {\n this.edit({ [InvalidValueSymbol]: newValue });\n }\n }\n\n private __renderLink(curie: string, href: string, title?: string) {\n return html`\n <li class=\"m-xs rounded overflow-hidden transition-colors hover-bg-contrast-5\">\n <foxy-swipe-actions>\n <button\n class=${classMap({\n 'rounded leading-none space-y-xs block text-left w-full py-s': true,\n 'ring-inset ring-primary-50': true,\n 'focus-outline-none focus-ring-2 ': true,\n })}\n @click=${() => {\n const evt = new CustomEvent('navigate:get', { bubbles: true, detail: href });\n this.dispatchEvent(evt);\n }}\n >\n <div class=\"flex items-center\">\n <div class=\"flex-1 space-y-xs px-s min-w-0 text-s\">\n <div class=\"truncate font-semibold\">${title || href}</div>\n <div class=\"opacity-75 truncate\">${curie}</div>\n </div>\n\n <iron-icon\n class=\"icon-inline text-xl text-tertiary mr-s flex-shrink-0\"\n icon=\"icons:chevron-right\"\n >\n </iron-icon>\n </div>\n </button>\n\n <div slot=\"action\" class=\"h-full flex\">\n <vaadin-button\n theme=\"secondary success\"\n class=\"h-full rounded-none\"\n @click=${() => {\n const evt = new CustomEvent('navigate:post', { bubbles: true, detail: href });\n this.dispatchEvent(evt);\n }}\n >\n POST\n </vaadin-button>\n </div>\n </foxy-swipe-actions>\n </li>\n `;\n }\n}\n"]}
@@ -0,0 +1,8 @@
1
+ import '@vaadin/vaadin-button';
2
+ import '@polymer/iron-icons';
3
+ import '@polymer/iron-icon';
4
+ import '../../../../internal/InternalForm/index';
5
+ import '../../../CopyToClipboard/index';
6
+ import '../../../SwipeActions/index';
7
+ import { InternalApiBrowserResourceForm as Form } from './InternalApiBrowserResourceForm';
8
+ export { Form as InternalApiBrowserResourceForm };
@@ -0,0 +1,10 @@
1
+ import '@vaadin/vaadin-button';
2
+ import '@polymer/iron-icons';
3
+ import '@polymer/iron-icon';
4
+ import "../../../../internal/InternalForm/index.js";
5
+ import "../../../CopyToClipboard/index.js";
6
+ import "../../../SwipeActions/index.js";
7
+ import { InternalApiBrowserResourceForm as Form } from "./InternalApiBrowserResourceForm.js";
8
+ customElements.define('foxy-internal-api-browser-resource-form', Form);
9
+ export { Form as InternalApiBrowserResourceForm };
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../src/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAC/B,OAAO,qBAAqB,CAAC;AAC7B,OAAO,oBAAoB,CAAC;AAE5B,oDAAiD;AACjD,2CAAwC;AACxC,wCAAqC;AAErC,OAAO,EAAE,8BAA8B,IAAI,IAAI,EAAE,4CAAyC;AAE1F,cAAc,CAAC,MAAM,CAAC,yCAAyC,EAAE,IAAI,CAAC,CAAC;AAEvE,OAAO,EAAE,IAAI,IAAI,8BAA8B,EAAE,CAAC","sourcesContent":["import '@vaadin/vaadin-button';\nimport '@polymer/iron-icons';\nimport '@polymer/iron-icon';\n\nimport '../../../../internal/InternalForm/index';\nimport '../../../CopyToClipboard/index';\nimport '../../../SwipeActions/index';\n\nimport { InternalApiBrowserResourceForm as Form } from './InternalApiBrowserResourceForm';\n\ncustomElements.define('foxy-internal-api-browser-resource-form', Form);\n\nexport { Form as InternalApiBrowserResourceForm };\n"]}
@@ -0,0 +1,10 @@
1
+ export declare type Link = {
2
+ href: string;
3
+ title: string;
4
+ templated: boolean;
5
+ };
6
+ export declare type Data = {
7
+ _links: Record<PropertyKey, Link> & {
8
+ self: Link;
9
+ };
10
+ };
@@ -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/ApiBrowser/types.ts"],"names":[],"mappings":"","sourcesContent":["export type Link = { href: string; title: string; templated: boolean };\nexport type Data = { _links: Record<PropertyKey, Link> & { self: Link } };\n"]}