@foxy.io/elements 1.15.0-beta.8 → 1.16.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 (667) 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 -0
  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 -0
  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 +15 -15
  24. package/dist/cdn/foxy-customer.js +7 -7
  25. package/dist/cdn/foxy-customers-table.js +1 -1
  26. package/dist/cdn/foxy-discount-builder.js +1 -0
  27. package/dist/cdn/foxy-discount-card.js +1 -1
  28. package/dist/cdn/foxy-discount-detail-card.js +1 -0
  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 -0
  40. package/dist/cdn/foxy-item-form.js +1 -0
  41. package/dist/cdn/foxy-item-option-card.js +1 -0
  42. package/dist/cdn/foxy-item-option-form.js +1 -0
  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 +195 -0
  50. package/dist/cdn/foxy-reports-table.js +41 -0
  51. package/dist/cdn/foxy-shipment-card.js +17 -0
  52. package/dist/cdn/foxy-sign-in-form.js +1 -1
  53. package/dist/cdn/foxy-spinner.js +2 -2
  54. package/dist/cdn/foxy-subscription-card.js +1 -1
  55. package/dist/cdn/foxy-subscription-form.js +5 -5
  56. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  57. package/dist/cdn/foxy-swipe-actions.js +1 -0
  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 +64 -0
  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 -0
  69. package/dist/cdn/foxy-webhook-form.js +318 -0
  70. package/dist/cdn/foxy-webhook-log-card.js +1 -0
  71. package/dist/cdn/foxy-webhook-status-card.js +1 -0
  72. package/dist/cdn/shared-0504c8dc.js +1 -0
  73. package/dist/cdn/{shared-5a54a9bc.js → shared-0c806443.js} +1 -1
  74. package/dist/cdn/{shared-218ba06e.js → shared-0eb966c5.js} +1 -1
  75. package/dist/cdn/shared-15b109e0.js +1 -0
  76. package/dist/cdn/{shared-1934524e.js → shared-17437844.js} +2 -2
  77. package/dist/cdn/{shared-59e44f29.js → shared-1bbd9b73.js} +1 -1
  78. package/dist/cdn/shared-1d67ea08.js +9 -0
  79. package/dist/cdn/{shared-07134f93.js → shared-22ba9566.js} +1 -1
  80. package/dist/cdn/{shared-448781f9.js → shared-26ce8d23.js} +1 -1
  81. package/dist/cdn/shared-322d50e3.js +1 -0
  82. package/dist/cdn/shared-32fe791c.js +1 -0
  83. package/dist/cdn/{shared-65dfd512.js → shared-3a31785e.js} +2 -11
  84. package/dist/cdn/shared-42883176.js +1 -0
  85. package/dist/cdn/shared-448cf4fc.js +1 -0
  86. package/dist/cdn/{shared-7f0a9790.js → shared-45feee83.js} +1 -1
  87. package/dist/cdn/shared-4d1b8098.js +1 -0
  88. package/dist/cdn/shared-59a3f7dd.js +1 -0
  89. package/dist/cdn/shared-6762b56b.js +12 -0
  90. package/dist/cdn/{shared-223508ae.js → shared-68ebb1d1.js} +7 -7
  91. package/dist/cdn/shared-6f03b699.js +1 -0
  92. package/dist/cdn/{shared-20b9ce70.js → shared-7312e29c.js} +1 -1
  93. package/dist/cdn/{shared-a040d79d.js → shared-7b02ce85.js} +1 -1
  94. package/dist/cdn/{shared-756034e4.js → shared-7c8bb60c.js} +1 -1
  95. package/dist/cdn/shared-7f264e87.js +1 -0
  96. package/dist/cdn/shared-8ada26b5.js +1 -0
  97. package/dist/cdn/{shared-60126eee.js → shared-8be42cfd.js} +1 -1
  98. package/dist/cdn/{shared-4dc6d228.js → shared-8c1f3b5d.js} +1 -1
  99. package/dist/cdn/{shared-5535f38f.js → shared-92327224.js} +2 -2
  100. package/dist/cdn/shared-94ec874e.js +1 -0
  101. package/dist/cdn/{shared-6d45a07b.js → shared-9803aa7c.js} +1 -1
  102. package/dist/cdn/shared-997e1923.js +1 -0
  103. package/dist/cdn/{shared-b0f0e8b5.js → shared-99940888.js} +1 -1
  104. package/dist/cdn/shared-a0617ac7.js +1 -0
  105. package/dist/cdn/{shared-b710881a.js → shared-a0c6a159.js} +2 -2
  106. package/dist/cdn/{shared-fab8c705.js → shared-a4f49e9c.js} +10 -10
  107. package/dist/cdn/{shared-08c63028.js → shared-a8bf2435.js} +14 -19
  108. package/dist/cdn/shared-a916ce20.js +1 -0
  109. package/dist/cdn/shared-ac44429d.js +1 -0
  110. package/dist/cdn/shared-b2b3f0e0.js +201 -0
  111. package/dist/cdn/{shared-073cb8e9.js → shared-b76a1f1d.js} +1 -1
  112. package/dist/cdn/{shared-e2c878c7.js → shared-c0c5d201.js} +10 -10
  113. package/dist/cdn/{shared-0f38a631.js → shared-cf9696be.js} +1 -1
  114. package/dist/cdn/{shared-f4ad24f4.js → shared-d1fae22a.js} +1 -1
  115. package/dist/cdn/shared-d6444ed0.js +1 -0
  116. package/dist/cdn/shared-d8ceb77e.js +1 -0
  117. package/dist/cdn/shared-dc73b9a5.js +159 -0
  118. package/dist/cdn/shared-df43b0ca.js +1 -0
  119. package/dist/cdn/{shared-1a67bc75.js → shared-e05209a8.js} +4 -4
  120. package/dist/cdn/{shared-9221e6b2.js → shared-e1c1e8e2.js} +1 -1
  121. package/dist/cdn/shared-e7634824.js +1 -0
  122. package/dist/cdn/shared-e82cc599.js +29 -0
  123. package/dist/cdn/shared-f9f9ed5b.js +6 -0
  124. package/dist/cdn/{shared-b9f18aaa.js → shared-fa7e21e7.js} +4 -4
  125. package/dist/cdn/shared-fadcb2e1.js +1 -0
  126. package/dist/cdn/{shared-46ee137f.js → shared-fd789489.js} +10 -10
  127. package/dist/cdn/translations/access-recovery-form/en.json +12 -0
  128. package/dist/cdn/translations/address-card/en.json +11 -0
  129. package/dist/cdn/translations/address-form/en.json +27 -0
  130. package/dist/cdn/translations/api-browser/en.json +28 -0
  131. package/dist/cdn/translations/applied-tax-card/en.json +9 -0
  132. package/dist/cdn/translations/attribute-card/en.json +7 -0
  133. package/dist/cdn/translations/attribute-form/en.json +22 -0
  134. package/dist/cdn/translations/cancellation-form/en.json +10 -0
  135. package/dist/cdn/translations/copy-to-clipboard/en.json +6 -0
  136. package/dist/cdn/translations/country/pl.json +251 -0
  137. package/dist/cdn/translations/coupon-card/en.json +36 -0
  138. package/dist/cdn/translations/coupon-code-form/en.json +17 -0
  139. package/dist/cdn/translations/coupon-codes-form/en.json +20 -0
  140. package/dist/cdn/translations/coupon-form/en.json +205 -0
  141. package/dist/cdn/translations/custom-field-card/en.json +7 -0
  142. package/dist/cdn/translations/custom-field-form/en.json +19 -0
  143. package/dist/cdn/translations/customer/en.json +247 -0
  144. package/dist/cdn/translations/customer-card/en.json +7 -0
  145. package/dist/cdn/translations/customer-form/en.json +21 -0
  146. package/dist/cdn/translations/customer-portal/de.json +202 -14
  147. package/dist/cdn/translations/customer-portal/en.json +202 -14
  148. package/dist/cdn/translations/customer-portal/es.json +202 -14
  149. package/dist/cdn/translations/customer-portal/pl.json +223 -0
  150. package/dist/cdn/translations/customer-portal/zh-hk.json +202 -14
  151. package/dist/cdn/translations/customers-table/en.json +9 -0
  152. package/dist/cdn/translations/discount-builder/en.json +14 -0
  153. package/dist/cdn/translations/discount-card/en.json +8 -0
  154. package/dist/cdn/translations/email-template-form/en.json +25 -0
  155. package/dist/cdn/translations/error-entry-card/en.json +7 -0
  156. package/dist/cdn/translations/generate-codes-form/en.json +19 -0
  157. package/dist/cdn/translations/gift-card-card/en.json +9 -0
  158. package/dist/cdn/translations/gift-card-code-form/en.json +19 -0
  159. package/dist/cdn/translations/gift-card-codes-form/en.json +25 -0
  160. package/dist/cdn/translations/gift-card-form/en.json +335 -0
  161. package/dist/cdn/translations/item-card/en.json +9 -0
  162. package/dist/cdn/translations/item-form/en.json +411 -0
  163. package/dist/cdn/translations/item-option-form/en.json +43 -0
  164. package/dist/cdn/translations/pagination/en.json +7 -0
  165. package/dist/cdn/translations/payment-card/en.json +12 -0
  166. package/dist/cdn/translations/payment-method-card/en.json +13 -0
  167. package/dist/cdn/translations/query-builder/en.json +32 -0
  168. package/dist/cdn/translations/report-form/en.json +38 -0
  169. package/dist/cdn/translations/reports-table/en.json +21 -0
  170. package/dist/cdn/translations/shipment-card/en.json +470 -0
  171. package/dist/cdn/translations/sign-in-form/en.json +21 -0
  172. package/dist/cdn/translations/spinner/en.json +7 -0
  173. package/dist/cdn/translations/subscription-card/en.json +26 -0
  174. package/dist/cdn/translations/subscription-form/en.json +76 -0
  175. package/dist/cdn/translations/subscriptions-table/en.json +26 -0
  176. package/dist/cdn/translations/tax-card/en.json +11 -0
  177. package/dist/cdn/translations/tax-form/en.json +38 -0
  178. package/dist/cdn/translations/template-config-form/en.json +107 -0
  179. package/dist/cdn/translations/template-form/en.json +23 -0
  180. package/dist/cdn/translations/transaction/en.json +965 -0
  181. package/dist/cdn/translations/transaction-card/en.json +25 -0
  182. package/dist/cdn/translations/transactions-table/en.json +22 -0
  183. package/dist/cdn/translations/user-form/en.json +26 -0
  184. package/dist/cdn/translations/users-table/en.json +44 -0
  185. package/dist/cdn/translations/webhook-card/en.json +7 -0
  186. package/dist/cdn/translations/webhook-form/en.json +101 -0
  187. package/dist/cdn/translations/webhook-log-card/en.json +8 -0
  188. package/dist/cdn/translations/webhook-status-card/en.json +11 -0
  189. package/dist/elements/index.d.ts +1 -0
  190. package/dist/elements/index.js +2 -0
  191. package/dist/elements/index.js.map +1 -0
  192. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.d.ts +22 -0
  193. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.js +79 -0
  194. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.js.map +1 -0
  195. package/dist/elements/internal/InternalAsyncComboBoxControl/index.d.ts +4 -0
  196. package/dist/elements/internal/InternalAsyncComboBoxControl/index.js +6 -0
  197. package/dist/elements/internal/InternalAsyncComboBoxControl/index.js.map +1 -0
  198. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.d.ts +30 -0
  199. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.js +131 -0
  200. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.js.map +1 -0
  201. package/dist/elements/internal/InternalAsyncDetailsControl/index.d.ts +7 -0
  202. package/dist/elements/internal/InternalAsyncDetailsControl/index.js +9 -0
  203. package/dist/elements/internal/InternalAsyncDetailsControl/index.js.map +1 -0
  204. package/dist/elements/internal/InternalCard/InternalCard.d.ts +21 -0
  205. package/dist/elements/internal/InternalCard/InternalCard.js +53 -0
  206. package/dist/elements/internal/InternalCard/InternalCard.js.map +1 -0
  207. package/dist/elements/internal/InternalCard/index.d.ts +3 -0
  208. package/dist/elements/internal/InternalCard/index.js +5 -0
  209. package/dist/elements/internal/InternalCard/index.js.map +1 -0
  210. package/dist/elements/internal/InternalControl/InternalControl.d.ts +21 -0
  211. package/dist/elements/internal/InternalControl/InternalControl.js +53 -0
  212. package/dist/elements/internal/InternalControl/InternalControl.js.map +1 -0
  213. package/dist/elements/internal/InternalControl/index.d.ts +2 -0
  214. package/dist/elements/internal/InternalControl/index.js +4 -0
  215. package/dist/elements/internal/InternalControl/index.js.map +1 -0
  216. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.d.ts +22 -0
  217. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.js +60 -0
  218. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.js.map +1 -0
  219. package/dist/elements/internal/InternalCreateControl/index.d.ts +5 -0
  220. package/dist/elements/internal/InternalCreateControl/index.js +7 -0
  221. package/dist/elements/internal/InternalCreateControl/index.js.map +1 -0
  222. package/dist/elements/internal/InternalDateControl/InternalDateControl.d.ts +14 -0
  223. package/dist/elements/internal/InternalDateControl/InternalDateControl.js +60 -0
  224. package/dist/elements/internal/InternalDateControl/InternalDateControl.js.map +1 -0
  225. package/dist/elements/internal/InternalDateControl/index.d.ts +4 -0
  226. package/dist/elements/internal/InternalDateControl/index.js +6 -0
  227. package/dist/elements/internal/InternalDateControl/index.js.map +1 -0
  228. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.d.ts +15 -0
  229. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.js +51 -0
  230. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.js.map +1 -0
  231. package/dist/elements/internal/InternalDeleteControl/index.d.ts +6 -0
  232. package/dist/elements/internal/InternalDeleteControl/index.js +8 -0
  233. package/dist/elements/internal/InternalDeleteControl/index.js.map +1 -0
  234. package/dist/elements/internal/InternalDetails/InternalDetails.d.ts +22 -0
  235. package/dist/elements/internal/InternalDetails/InternalDetails.js +71 -0
  236. package/dist/elements/internal/InternalDetails/InternalDetails.js.map +1 -0
  237. package/dist/elements/internal/InternalDetails/index.d.ts +6 -0
  238. package/dist/elements/internal/InternalDetails/index.js +8 -0
  239. package/dist/elements/internal/InternalDetails/index.js.map +1 -0
  240. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.d.ts +25 -0
  241. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.js +78 -0
  242. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.js.map +1 -0
  243. package/dist/elements/internal/InternalEditableControl/index.d.ts +3 -0
  244. package/dist/elements/internal/InternalEditableControl/index.js +5 -0
  245. package/dist/elements/internal/InternalEditableControl/index.js.map +1 -0
  246. package/dist/elements/internal/InternalForm/InternalForm.d.ts +11 -0
  247. package/dist/elements/internal/InternalForm/InternalForm.js +48 -0
  248. package/dist/elements/internal/InternalForm/InternalForm.js.map +1 -0
  249. package/dist/elements/internal/InternalForm/index.d.ts +6 -0
  250. package/dist/elements/internal/InternalForm/index.js +8 -0
  251. package/dist/elements/internal/InternalForm/index.js.map +1 -0
  252. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/InternalTimestampsControl.d.ts +8 -0
  253. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/InternalTimestampsControl.js +56 -0
  254. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/InternalTimestampsControl.js.map +1 -0
  255. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/index.d.ts +2 -0
  256. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/index.js +4 -0
  257. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/index.js.map +1 -0
  258. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.d.ts +14 -0
  259. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.js +115 -0
  260. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.js.map +1 -0
  261. package/dist/elements/internal/InternalFrequencyControl/index.d.ts +6 -0
  262. package/dist/elements/internal/InternalFrequencyControl/index.js +8 -0
  263. package/dist/elements/internal/InternalFrequencyControl/index.js.map +1 -0
  264. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.d.ts +13 -0
  265. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.js +41 -0
  266. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.js.map +1 -0
  267. package/dist/elements/internal/InternalIntegerControl/index.d.ts +4 -0
  268. package/dist/elements/internal/InternalIntegerControl/index.js +6 -0
  269. package/dist/elements/internal/InternalIntegerControl/index.js.map +1 -0
  270. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.d.ts +13 -0
  271. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js +41 -0
  272. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js.map +1 -0
  273. package/dist/elements/internal/InternalNumberControl/index.d.ts +4 -0
  274. package/dist/elements/internal/InternalNumberControl/index.js +6 -0
  275. package/dist/elements/internal/InternalNumberControl/index.js.map +1 -0
  276. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.d.ts +17 -0
  277. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js +51 -0
  278. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js.map +1 -0
  279. package/dist/elements/internal/InternalRadioGroupControl/index.d.ts +6 -0
  280. package/dist/elements/internal/InternalRadioGroupControl/index.js +8 -0
  281. package/dist/elements/internal/InternalRadioGroupControl/index.js.map +1 -0
  282. package/dist/elements/internal/InternalRadioGroupControl/types.d.ts +6 -0
  283. package/dist/elements/internal/InternalRadioGroupControl/types.js +2 -0
  284. package/dist/elements/internal/InternalRadioGroupControl/types.js.map +1 -0
  285. package/dist/elements/internal/InternalTextControl/InternalTextControl.d.ts +13 -0
  286. package/dist/elements/internal/InternalTextControl/InternalTextControl.js +40 -0
  287. package/dist/elements/internal/InternalTextControl/InternalTextControl.js.map +1 -0
  288. package/dist/elements/internal/InternalTextControl/index.d.ts +4 -0
  289. package/dist/elements/internal/InternalTextControl/index.js +6 -0
  290. package/dist/elements/internal/InternalTextControl/index.js.map +1 -0
  291. package/dist/elements/private/Choice/Choice.js +1 -0
  292. package/dist/elements/private/Choice/Choice.js.map +1 -1
  293. package/dist/elements/private/Dialog/Dialog.d.ts +4 -2
  294. package/dist/elements/private/Dialog/Dialog.js +3 -1
  295. package/dist/elements/private/Dialog/Dialog.js.map +1 -1
  296. package/dist/elements/private/EditableList/EditableList.d.ts +4 -2
  297. package/dist/elements/private/EditableList/EditableList.js +3 -1
  298. package/dist/elements/private/EditableList/EditableList.js.map +1 -1
  299. package/dist/elements/private/FrequencyInput/FrequencyInput.d.ts +7 -5
  300. package/dist/elements/private/FrequencyInput/FrequencyInput.js +8 -22
  301. package/dist/elements/private/FrequencyInput/FrequencyInput.js.map +1 -1
  302. package/dist/elements/public/AccessRecoveryForm/AccessRecoveryForm.js +1 -1
  303. package/dist/elements/public/AccessRecoveryForm/AccessRecoveryForm.js.map +1 -1
  304. package/dist/elements/public/ApiBrowser/ApiBrowser.d.ts +31 -0
  305. package/dist/elements/public/ApiBrowser/ApiBrowser.js +215 -0
  306. package/dist/elements/public/ApiBrowser/ApiBrowser.js.map +1 -0
  307. package/dist/elements/public/ApiBrowser/index.d.ts +9 -0
  308. package/dist/elements/public/ApiBrowser/index.js +11 -0
  309. package/dist/elements/public/ApiBrowser/index.js.map +1 -0
  310. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.d.ts +25 -0
  311. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js +285 -0
  312. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js.map +1 -0
  313. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.d.ts +10 -0
  314. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js +12 -0
  315. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js.map +1 -0
  316. package/dist/elements/public/ApiBrowser/types.d.ts +10 -0
  317. package/dist/elements/public/ApiBrowser/types.js +2 -0
  318. package/dist/elements/public/ApiBrowser/types.js.map +1 -0
  319. package/dist/elements/public/AttributeCard/types.d.ts +3 -3
  320. package/dist/elements/public/AttributeCard/types.js.map +1 -1
  321. package/dist/elements/public/AttributeForm/AttributeForm.js +2 -1
  322. package/dist/elements/public/AttributeForm/AttributeForm.js.map +1 -1
  323. package/dist/elements/public/AttributeForm/types.d.ts +3 -3
  324. package/dist/elements/public/AttributeForm/types.js.map +1 -1
  325. package/dist/elements/public/CollectionPage/CollectionPage.d.ts +4 -3
  326. package/dist/elements/public/CollectionPage/CollectionPage.js +5 -3
  327. package/dist/elements/public/CollectionPage/CollectionPage.js.map +1 -1
  328. package/dist/elements/public/CollectionPage/types.d.ts +1 -0
  329. package/dist/elements/public/CollectionPage/types.js.map +1 -1
  330. package/dist/elements/public/CollectionPages/CollectionPages.d.ts +4 -2
  331. package/dist/elements/public/CollectionPages/CollectionPages.js +3 -1
  332. package/dist/elements/public/CollectionPages/CollectionPages.js.map +1 -1
  333. package/dist/elements/public/CopyToClipboard/CopyToClipboard.d.ts +22 -0
  334. package/dist/elements/public/CopyToClipboard/CopyToClipboard.js +121 -0
  335. package/dist/elements/public/CopyToClipboard/CopyToClipboard.js.map +1 -0
  336. package/dist/elements/public/CopyToClipboard/index.d.ts +5 -0
  337. package/dist/elements/public/CopyToClipboard/index.js +7 -0
  338. package/dist/elements/public/CopyToClipboard/index.js.map +1 -0
  339. package/dist/elements/public/CouponCard/CouponCard.js +2 -1
  340. package/dist/elements/public/CouponCard/CouponCard.js.map +1 -1
  341. package/dist/elements/public/CouponCodeForm/CouponCodeForm.js +5 -5
  342. package/dist/elements/public/CouponCodeForm/CouponCodeForm.js.map +1 -1
  343. package/dist/elements/public/CouponDetailCard/CouponDetailCard.d.ts +25 -0
  344. package/dist/elements/public/CouponDetailCard/CouponDetailCard.js +58 -0
  345. package/dist/elements/public/CouponDetailCard/CouponDetailCard.js.map +1 -0
  346. package/dist/elements/public/CouponDetailCard/index.d.ts +5 -0
  347. package/dist/elements/public/CouponDetailCard/index.js +7 -0
  348. package/dist/elements/public/CouponDetailCard/index.js.map +1 -0
  349. package/dist/elements/public/CouponDetailCard/types.d.ts +3 -0
  350. package/dist/elements/public/CouponDetailCard/types.js +2 -0
  351. package/dist/elements/public/CouponDetailCard/types.js.map +1 -0
  352. package/dist/elements/public/CouponForm/CouponForm.js +232 -196
  353. package/dist/elements/public/CouponForm/CouponForm.js.map +1 -1
  354. package/dist/elements/public/CouponForm/index.d.ts +1 -0
  355. package/dist/elements/public/CouponForm/index.js +1 -0
  356. package/dist/elements/public/CouponForm/index.js.map +1 -1
  357. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.d.ts +4 -3
  358. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.js +5 -4
  359. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPage.js.map +1 -1
  360. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.d.ts +3 -4
  361. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.js +3 -4
  362. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItem.js.map +1 -1
  363. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.d.ts +3 -4
  364. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.js +3 -2
  365. package/dist/elements/public/CouponForm/private/CategoryRestrictionsPageItemContent.js.map +1 -1
  366. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js +2 -1
  367. package/dist/elements/public/CustomFieldForm/CustomFieldForm.js.map +1 -1
  368. package/dist/elements/public/Customer/Customer.js +1 -1
  369. package/dist/elements/public/Customer/Customer.js.map +1 -1
  370. package/dist/elements/public/CustomerApi/CustomerApi.d.ts +3 -1
  371. package/dist/elements/public/CustomerApi/CustomerApi.js +2 -1
  372. package/dist/elements/public/CustomerApi/CustomerApi.js.map +1 -1
  373. package/dist/elements/public/CustomerPortal/InternalCustomerPortalChangePassword.d.ts +3 -1
  374. package/dist/elements/public/CustomerPortal/InternalCustomerPortalChangePassword.js +2 -1
  375. package/dist/elements/public/CustomerPortal/InternalCustomerPortalChangePassword.js.map +1 -1
  376. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedInView.js +18 -5
  377. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedInView.js.map +1 -1
  378. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedOutView.d.ts +3 -1
  379. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedOutView.js +22 -7
  380. package/dist/elements/public/CustomerPortal/InternalCustomerPortalLoggedOutView.js.map +1 -1
  381. package/dist/elements/public/CustomerPortal/InternalCustomerPortalSubscriptions.d.ts +3 -1
  382. package/dist/elements/public/CustomerPortal/InternalCustomerPortalSubscriptions.js +4 -2
  383. package/dist/elements/public/CustomerPortal/InternalCustomerPortalSubscriptions.js.map +1 -1
  384. package/dist/elements/public/CustomerPortal/InternalCustomerPortalTransactions.d.ts +3 -1
  385. package/dist/elements/public/CustomerPortal/InternalCustomerPortalTransactions.js +2 -1
  386. package/dist/elements/public/CustomerPortal/InternalCustomerPortalTransactions.js.map +1 -1
  387. package/dist/elements/public/DiscountBuilder/DiscountBuilder.d.ts +40 -0
  388. package/dist/elements/public/DiscountBuilder/DiscountBuilder.js +342 -0
  389. package/dist/elements/public/DiscountBuilder/DiscountBuilder.js.map +1 -0
  390. package/dist/elements/public/DiscountBuilder/index.d.ts +3 -0
  391. package/dist/elements/public/DiscountBuilder/index.js +5 -0
  392. package/dist/elements/public/DiscountBuilder/index.js.map +1 -0
  393. package/dist/elements/public/DiscountBuilder/types.d.ts +32 -0
  394. package/dist/elements/public/DiscountBuilder/types.js +2 -0
  395. package/dist/elements/public/DiscountBuilder/types.js.map +1 -0
  396. package/dist/elements/public/DiscountDetailCard/DiscountDetailCard.d.ts +25 -0
  397. package/dist/elements/public/DiscountDetailCard/DiscountDetailCard.js +58 -0
  398. package/dist/elements/public/DiscountDetailCard/DiscountDetailCard.js.map +1 -0
  399. package/dist/elements/public/DiscountDetailCard/index.d.ts +5 -0
  400. package/dist/elements/public/DiscountDetailCard/index.js +7 -0
  401. package/dist/elements/public/DiscountDetailCard/index.js.map +1 -0
  402. package/dist/elements/public/DiscountDetailCard/types.d.ts +3 -0
  403. package/dist/elements/public/DiscountDetailCard/types.js +2 -0
  404. package/dist/elements/public/DiscountDetailCard/types.js.map +1 -0
  405. package/dist/elements/public/ErrorEntryCard/ErrorEntryCard.js +2 -1
  406. package/dist/elements/public/ErrorEntryCard/ErrorEntryCard.js.map +1 -1
  407. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js +6 -6
  408. package/dist/elements/public/GiftCardCodeForm/GiftCardCodeForm.js.map +1 -1
  409. package/dist/elements/public/GiftCardForm/GiftCardForm.js +130 -99
  410. package/dist/elements/public/GiftCardForm/GiftCardForm.js.map +1 -1
  411. package/dist/elements/public/GiftCardForm/index.d.ts +1 -0
  412. package/dist/elements/public/GiftCardForm/index.js +1 -0
  413. package/dist/elements/public/GiftCardForm/index.js.map +1 -1
  414. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.d.ts +1 -1
  415. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js +3 -3
  416. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPage.js.map +1 -1
  417. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.d.ts +1 -3
  418. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js +2 -4
  419. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItem.js.map +1 -1
  420. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.d.ts +1 -3
  421. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js +2 -2
  422. package/dist/elements/public/GiftCardForm/private/CategoryRestrictionsPageItemContent.js.map +1 -1
  423. package/dist/elements/public/I18n/I18n.d.ts +3 -1
  424. package/dist/elements/public/I18n/I18n.js +2 -1
  425. package/dist/elements/public/I18n/I18n.js.map +1 -1
  426. package/dist/elements/public/I18n/format/discount.js +3 -2
  427. package/dist/elements/public/I18n/format/discount.js.map +1 -1
  428. package/dist/elements/public/ItemCard/ItemCard.d.ts +16 -0
  429. package/dist/elements/public/ItemCard/ItemCard.js +142 -0
  430. package/dist/elements/public/ItemCard/ItemCard.js.map +1 -0
  431. package/dist/elements/public/ItemCard/index.d.ts +4 -0
  432. package/dist/elements/public/ItemCard/index.js +6 -0
  433. package/dist/elements/public/ItemCard/index.js.map +1 -0
  434. package/dist/elements/public/ItemCard/types.d.ts +5 -0
  435. package/dist/elements/public/ItemCard/types.js +2 -0
  436. package/dist/elements/public/ItemCard/types.js.map +1 -0
  437. package/dist/elements/public/ItemForm/ItemForm.d.ts +19 -0
  438. package/dist/elements/public/ItemForm/ItemForm.js +96 -0
  439. package/dist/elements/public/ItemForm/ItemForm.js.map +1 -0
  440. package/dist/elements/public/ItemForm/index.d.ts +19 -0
  441. package/dist/elements/public/ItemForm/index.js +21 -0
  442. package/dist/elements/public/ItemForm/index.js.map +1 -0
  443. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.d.ts +6 -0
  444. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js +23 -0
  445. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js.map +1 -0
  446. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.d.ts +6 -0
  447. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js +8 -0
  448. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js.map +1 -0
  449. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.d.ts +6 -0
  450. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js +31 -0
  451. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js.map +1 -0
  452. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.d.ts +5 -0
  453. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js +7 -0
  454. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js.map +1 -0
  455. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.d.ts +6 -0
  456. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js +48 -0
  457. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js.map +1 -0
  458. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.d.ts +7 -0
  459. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.js +9 -0
  460. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/index.js.map +1 -0
  461. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.d.ts +6 -0
  462. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js +32 -0
  463. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js.map +1 -0
  464. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.d.ts +5 -0
  465. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js +7 -0
  466. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js.map +1 -0
  467. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.d.ts +6 -0
  468. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js +75 -0
  469. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js.map +1 -0
  470. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.d.ts +8 -0
  471. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js +10 -0
  472. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js.map +1 -0
  473. package/dist/elements/public/ItemForm/types.d.ts +3 -0
  474. package/dist/elements/public/ItemForm/types.js +2 -0
  475. package/dist/elements/public/ItemForm/types.js.map +1 -0
  476. package/dist/elements/public/ItemOptionCard/ItemOptionCard.d.ts +25 -0
  477. package/dist/elements/public/ItemOptionCard/ItemOptionCard.js +56 -0
  478. package/dist/elements/public/ItemOptionCard/ItemOptionCard.js.map +1 -0
  479. package/dist/elements/public/ItemOptionCard/index.d.ts +6 -0
  480. package/dist/elements/public/ItemOptionCard/index.js +8 -0
  481. package/dist/elements/public/ItemOptionCard/index.js.map +1 -0
  482. package/dist/elements/public/ItemOptionCard/types.d.ts +11 -0
  483. package/dist/elements/public/ItemOptionCard/types.js +2 -0
  484. package/dist/elements/public/ItemOptionCard/types.js.map +1 -0
  485. package/dist/elements/public/ItemOptionForm/ItemOptionForm.d.ts +30 -0
  486. package/dist/elements/public/ItemOptionForm/ItemOptionForm.js +41 -0
  487. package/dist/elements/public/ItemOptionForm/ItemOptionForm.js.map +1 -0
  488. package/dist/elements/public/ItemOptionForm/index.d.ts +5 -0
  489. package/dist/elements/public/ItemOptionForm/index.js +7 -0
  490. package/dist/elements/public/ItemOptionForm/index.js.map +1 -0
  491. package/dist/elements/public/ItemOptionForm/types.d.ts +3 -0
  492. package/dist/elements/public/ItemOptionForm/types.js +2 -0
  493. package/dist/elements/public/ItemOptionForm/types.js.map +1 -0
  494. package/dist/elements/public/NucleonElement/NucleonElement.d.ts +7 -1
  495. package/dist/elements/public/NucleonElement/NucleonElement.js +13 -1
  496. package/dist/elements/public/NucleonElement/NucleonElement.js.map +1 -1
  497. package/dist/elements/public/Pagination/Pagination.d.ts +3 -1
  498. package/dist/elements/public/Pagination/Pagination.js +7 -2
  499. package/dist/elements/public/Pagination/Pagination.js.map +1 -1
  500. package/dist/elements/public/PaymentCard/PaymentCard.js +1 -1
  501. package/dist/elements/public/PaymentCard/PaymentCard.js.map +1 -1
  502. package/dist/elements/public/QueryBuilder/QueryBuilder.d.ts +3 -1
  503. package/dist/elements/public/QueryBuilder/QueryBuilder.js +2 -1
  504. package/dist/elements/public/QueryBuilder/QueryBuilder.js.map +1 -1
  505. package/dist/elements/public/ReportForm/ReportForm.d.ts +48 -0
  506. package/dist/elements/public/ReportForm/ReportForm.js +391 -0
  507. package/dist/elements/public/ReportForm/ReportForm.js.map +1 -0
  508. package/dist/elements/public/ReportForm/index.d.ts +11 -0
  509. package/dist/elements/public/ReportForm/index.js +13 -0
  510. package/dist/elements/public/ReportForm/index.js.map +1 -0
  511. package/dist/elements/public/ReportForm/types.d.ts +17 -0
  512. package/dist/elements/public/ReportForm/types.js +2 -0
  513. package/dist/elements/public/ReportForm/types.js.map +1 -0
  514. package/dist/elements/public/ReportForm/utils.d.ts +16 -0
  515. package/dist/elements/public/ReportForm/utils.js +73 -0
  516. package/dist/elements/public/ReportForm/utils.js.map +1 -0
  517. package/dist/elements/public/ReportsTable/ReportsTable.d.ts +21 -0
  518. package/dist/elements/public/ReportsTable/ReportsTable.js +101 -0
  519. package/dist/elements/public/ReportsTable/ReportsTable.js.map +1 -0
  520. package/dist/elements/public/ReportsTable/index.d.ts +4 -0
  521. package/dist/elements/public/ReportsTable/index.js +6 -0
  522. package/dist/elements/public/ReportsTable/index.js.map +1 -0
  523. package/dist/elements/public/ReportsTable/types.d.ts +3 -0
  524. package/dist/elements/public/ReportsTable/types.js +2 -0
  525. package/dist/elements/public/ReportsTable/types.js.map +1 -0
  526. package/dist/elements/public/ShipmentCard/ShipmentCard.d.ts +22 -0
  527. package/dist/elements/public/ShipmentCard/ShipmentCard.js +117 -0
  528. package/dist/elements/public/ShipmentCard/ShipmentCard.js.map +1 -0
  529. package/dist/elements/public/ShipmentCard/index.d.ts +7 -0
  530. package/dist/elements/public/ShipmentCard/index.js +9 -0
  531. package/dist/elements/public/ShipmentCard/index.js.map +1 -0
  532. package/dist/elements/public/ShipmentCard/types.d.ts +18 -0
  533. package/dist/elements/public/ShipmentCard/types.js +2 -0
  534. package/dist/elements/public/ShipmentCard/types.js.map +1 -0
  535. package/dist/elements/public/SignInForm/SignInForm.js +1 -1
  536. package/dist/elements/public/SignInForm/SignInForm.js.map +1 -1
  537. package/dist/elements/public/Spinner/Spinner.d.ts +4 -2
  538. package/dist/elements/public/Spinner/Spinner.js +3 -1
  539. package/dist/elements/public/Spinner/Spinner.js.map +1 -1
  540. package/dist/elements/public/SubscriptionForm/SubscriptionForm.js +1 -1
  541. package/dist/elements/public/SubscriptionForm/SubscriptionForm.js.map +1 -1
  542. package/dist/elements/public/SwipeActions/SwipeActions.d.ts +13 -0
  543. package/dist/elements/public/SwipeActions/SwipeActions.js +116 -0
  544. package/dist/elements/public/SwipeActions/SwipeActions.js.map +1 -0
  545. package/dist/elements/public/SwipeActions/index.d.ts +2 -0
  546. package/dist/elements/public/SwipeActions/index.js +4 -0
  547. package/dist/elements/public/SwipeActions/index.js.map +1 -0
  548. package/dist/elements/public/TaxForm/TaxForm.js +16 -14
  549. package/dist/elements/public/TaxForm/TaxForm.js.map +1 -1
  550. package/dist/elements/public/TemplateForm/TemplateForm.js +1 -1
  551. package/dist/elements/public/TemplateForm/TemplateForm.js.map +1 -1
  552. package/dist/elements/public/Transaction/Transaction.d.ts +13 -0
  553. package/dist/elements/public/Transaction/Transaction.js +101 -0
  554. package/dist/elements/public/Transaction/Transaction.js.map +1 -0
  555. package/dist/elements/public/Transaction/index.d.ts +19 -0
  556. package/dist/elements/public/Transaction/index.js +21 -0
  557. package/dist/elements/public/Transaction/index.js.map +1 -0
  558. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/InternalTransactionActionsControl.d.ts +9 -0
  559. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/InternalTransactionActionsControl.js +69 -0
  560. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/InternalTransactionActionsControl.js.map +1 -0
  561. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/index.d.ts +4 -0
  562. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/index.js +6 -0
  563. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/index.js.map +1 -0
  564. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.d.ts +5 -0
  565. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js +36 -0
  566. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js.map +1 -0
  567. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.d.ts +7 -0
  568. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.js +9 -0
  569. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/index.js.map +1 -0
  570. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.d.ts +11 -0
  571. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.js +61 -0
  572. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.js.map +1 -0
  573. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.d.ts +6 -0
  574. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.js +8 -0
  575. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.js.map +1 -0
  576. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/InternalTransactionSummaryControl.d.ts +8 -0
  577. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/InternalTransactionSummaryControl.js +77 -0
  578. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/InternalTransactionSummaryControl.js.map +1 -0
  579. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/index.d.ts +4 -0
  580. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/index.js +6 -0
  581. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/index.js.map +1 -0
  582. package/dist/elements/public/Transaction/types.d.ts +3 -0
  583. package/dist/elements/public/Transaction/types.js +2 -0
  584. package/dist/elements/public/Transaction/types.js.map +1 -0
  585. package/dist/elements/public/UserForm/UserForm.js +2 -1
  586. package/dist/elements/public/UserForm/UserForm.js.map +1 -1
  587. package/dist/elements/public/UsersTable/UsersTable.d.ts +5 -1
  588. package/dist/elements/public/UsersTable/UsersTable.js +2 -1
  589. package/dist/elements/public/UsersTable/UsersTable.js.map +1 -1
  590. package/dist/elements/public/WebhookCard/WebhookCard.d.ts +16 -0
  591. package/dist/elements/public/WebhookCard/WebhookCard.js +36 -0
  592. package/dist/elements/public/WebhookCard/WebhookCard.js.map +1 -0
  593. package/dist/elements/public/WebhookCard/index.d.ts +5 -0
  594. package/dist/elements/public/WebhookCard/index.js +7 -0
  595. package/dist/elements/public/WebhookCard/index.js.map +1 -0
  596. package/dist/elements/public/WebhookCard/types.d.ts +3 -0
  597. package/dist/elements/public/WebhookCard/types.js +2 -0
  598. package/dist/elements/public/WebhookCard/types.js.map +1 -0
  599. package/dist/elements/public/WebhookForm/WebhookForm.d.ts +47 -0
  600. package/dist/elements/public/WebhookForm/WebhookForm.js +101 -0
  601. package/dist/elements/public/WebhookForm/WebhookForm.js.map +1 -0
  602. package/dist/elements/public/WebhookForm/index.d.ts +8 -0
  603. package/dist/elements/public/WebhookForm/index.js +10 -0
  604. package/dist/elements/public/WebhookForm/index.js.map +1 -0
  605. package/dist/elements/public/WebhookForm/types.d.ts +3 -0
  606. package/dist/elements/public/WebhookForm/types.js +2 -0
  607. package/dist/elements/public/WebhookForm/types.js.map +1 -0
  608. package/dist/elements/public/WebhookLogCard/WebhookLogCard.d.ts +16 -0
  609. package/dist/elements/public/WebhookLogCard/WebhookLogCard.js +28 -0
  610. package/dist/elements/public/WebhookLogCard/WebhookLogCard.js.map +1 -0
  611. package/dist/elements/public/WebhookLogCard/index.d.ts +4 -0
  612. package/dist/elements/public/WebhookLogCard/index.js +6 -0
  613. package/dist/elements/public/WebhookLogCard/index.js.map +1 -0
  614. package/dist/elements/public/WebhookLogCard/types.d.ts +3 -0
  615. package/dist/elements/public/WebhookLogCard/types.js +2 -0
  616. package/dist/elements/public/WebhookLogCard/types.js.map +1 -0
  617. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.d.ts +16 -0
  618. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.js +41 -0
  619. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.js.map +1 -0
  620. package/dist/elements/public/WebhookStatusCard/index.d.ts +4 -0
  621. package/dist/elements/public/WebhookStatusCard/index.js +6 -0
  622. package/dist/elements/public/WebhookStatusCard/index.js.map +1 -0
  623. package/dist/elements/public/WebhookStatusCard/types.d.ts +3 -0
  624. package/dist/elements/public/WebhookStatusCard/types.js +2 -0
  625. package/dist/elements/public/WebhookStatusCard/types.js.map +1 -0
  626. package/dist/elements/public/index.d.ts +18 -0
  627. package/dist/elements/public/index.defined.d.ts +18 -0
  628. package/dist/elements/public/index.defined.js +18 -0
  629. package/dist/elements/public/index.defined.js.map +1 -1
  630. package/dist/elements/public/index.js +18 -0
  631. package/dist/elements/public/index.js.map +1 -1
  632. package/dist/mixins/configurable.d.ts +5 -3
  633. package/dist/mixins/configurable.js +39 -4
  634. package/dist/mixins/configurable.js.map +1 -1
  635. package/dist/mixins/inferrable.d.ts +15 -0
  636. package/dist/mixins/inferrable.js +67 -0
  637. package/dist/mixins/inferrable.js.map +1 -0
  638. package/dist/mixins/themeable.js +6836 -13
  639. package/dist/mixins/themeable.js.map +1 -1
  640. package/dist/mixins/translatable.d.ts +3 -1
  641. package/dist/mixins/translatable.js +17 -3
  642. package/dist/mixins/translatable.js.map +1 -1
  643. package/package.json +3 -3
  644. package/dist/cdn/shared-02945b27.js +0 -1
  645. package/dist/cdn/shared-07049bfe.js +0 -1
  646. package/dist/cdn/shared-09069d7c.js +0 -1
  647. package/dist/cdn/shared-11708514.js +0 -1
  648. package/dist/cdn/shared-21419f10.js +0 -1
  649. package/dist/cdn/shared-253e59d2.js +0 -1
  650. package/dist/cdn/shared-39e3ae67.js +0 -1
  651. package/dist/cdn/shared-63eaded9.js +0 -159
  652. package/dist/cdn/shared-66633ff7.js +0 -1
  653. package/dist/cdn/shared-805d18a2.js +0 -1
  654. package/dist/cdn/shared-8b20bc23.js +0 -12
  655. package/dist/cdn/shared-a23cf7c8.js +0 -1
  656. package/dist/cdn/shared-a7b6feb2.js +0 -1
  657. package/dist/cdn/shared-b5754a42.js +0 -1
  658. package/dist/cdn/shared-c5de42f7.js +0 -1
  659. package/dist/cdn/shared-dcc9c325.js +0 -1
  660. package/dist/cdn/shared-df730f90.js +0 -1
  661. package/dist/cdn/shared-e209cb55.js +0 -1
  662. package/dist/cdn/shared-e68b9c83.js +0 -1
  663. package/dist/cdn/shared-ff79f3f9.js +0 -230
  664. package/dist/cdn/translations/shared/de.json +0 -271
  665. package/dist/cdn/translations/shared/en.json +0 -557
  666. package/dist/cdn/translations/shared/es.json +0 -272
  667. package/dist/cdn/translations/shared/zh-hk.json +0 -179
@@ -0,0 +1,285 @@
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
+ textarea::selection{
42
+ background:var(--lumo-contrast-10pct);
43
+ }
44
+ `,
45
+ ];
46
+ }
47
+ static get v8n() {
48
+ return [
49
+ ...super.v8n,
50
+ v => (typeof v[InvalidValueSymbol] === 'string' ? 'invalid_json' : true),
51
+ ];
52
+ }
53
+ renderBody() {
54
+ return html `
55
+ <details
56
+ class="select-none rounded-t-l rounded-b-l overflow-hidden border border-contrast-10"
57
+ ?open=${this.open}
58
+ @toggle=${(evt) => {
59
+ const details = evt.currentTarget;
60
+ this.open = details.open;
61
+ }}
62
+ >
63
+ <summary
64
+ class=${classMap({
65
+ 'ring-inset ring-primary-50 rounded-t-l': true,
66
+ 'focus-outline-none focus-ring-2': true,
67
+ 'rounded-b-l': !this.open,
68
+ })}
69
+ >
70
+ <div
71
+ class="flex items-center space-x-s p-s pr-m transition-colors cursor-pointer bg-contrast-5 hover-bg-contrast-10"
72
+ >
73
+ <foxy-copy-to-clipboard infer="copy-to-clipboard" text=${this.href || this.parent}>
74
+ </foxy-copy-to-clipboard>
75
+
76
+ <span class="font-semibold truncate">${this.__renderTitle()}</span>
77
+ <span class="flex-1"></span>
78
+
79
+ ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: 'template' })
80
+ ? html `
81
+ <foxy-internal-create-control infer="create" theme="tertiary-inline success">
82
+ </foxy-internal-create-control>
83
+ `
84
+ : ''}
85
+ ${this.in({ idle: { snapshot: 'dirty' } }) || this.in({ idle: { template: 'dirty' } })
86
+ ? html `
87
+ <vaadin-button
88
+ theme="tertiary-inline contrast"
89
+ class="px-xs"
90
+ @click=${() => this.undo()}
91
+ >
92
+ <foxy-i18n infer="" key="undo"></foxy-i18n>
93
+ </vaadin-button>
94
+ `
95
+ : ''}
96
+ ${this.in({ idle: 'snapshot' })
97
+ ? html `
98
+ <foxy-internal-delete-control infer="delete" theme="tertiary-inline error">
99
+ </foxy-internal-delete-control>
100
+ `
101
+ : ''}
102
+ </div>
103
+ </summary>
104
+
105
+ ${this.open ? this.__renderForm() : ''}
106
+ </details>
107
+ `;
108
+ }
109
+ updated(changes) {
110
+ super.updated(changes);
111
+ this.__setTextAreaHeight();
112
+ }
113
+ async _fetch(...args) {
114
+ try {
115
+ const request = args[0] instanceof Request ? args[0] : new Request(...args);
116
+ if (request.method !== 'POST')
117
+ return await super._fetch(...args);
118
+ const body = this.form[ValidValueSymbol];
119
+ return await super._fetch(request.url, { method: 'POST', body });
120
+ }
121
+ catch (err) {
122
+ throw ['invalid_json'];
123
+ }
124
+ }
125
+ __setTextAreaHeight() {
126
+ const textarea = this.renderRoot.querySelector('textarea');
127
+ if (textarea) {
128
+ textarea.style.height = 'auto';
129
+ textarea.style.height = `${textarea.scrollHeight}px`;
130
+ textarea.style.overflowY = 'hidden';
131
+ }
132
+ }
133
+ __renderTitle() {
134
+ if (!this.href) {
135
+ return html `
136
+ <span class="text-tertiary">POST</span>
137
+ <span>${this.parent}</span>
138
+ `;
139
+ }
140
+ let pathname = '';
141
+ let identifier = '';
142
+ let search = '';
143
+ try {
144
+ const url = new URL(this.href);
145
+ pathname = url.pathname;
146
+ if (pathname.startsWith('/'))
147
+ pathname = pathname.substring(1);
148
+ const splitPathname = pathname.split('/');
149
+ pathname = splitPathname.slice(0, splitPathname.length - 1).join('/');
150
+ if (splitPathname.length > 1) {
151
+ pathname = `${pathname}/`;
152
+ identifier = splitPathname[splitPathname.length - 1];
153
+ }
154
+ search = url.search;
155
+ }
156
+ catch (_a) {
157
+ pathname = this.href;
158
+ }
159
+ return html `
160
+ ${[
161
+ html `<span>${pathname}</span>`,
162
+ html `<span class="text-primary">${identifier}</span>`,
163
+ html `<span class="text-tertiary">${search}</span>`,
164
+ ]}
165
+ `;
166
+ }
167
+ __renderForm() {
168
+ return html `
169
+ <div class="bg-base">
170
+ <div class="${this.data ? 'resource' : ''} border-t border-contrast-5 bg-contrast-10">
171
+ <div class="flex-1 flex bg-base">
172
+ <div class="monospace bg-contrast-5 leading-s text-s p-m text-tertiary text-right">
173
+ ${this.__formAsString.split('\n').map((_, index) => html `<div>${index + 1}</div>`)}
174
+ </div>
175
+
176
+ <textarea
177
+ class=${classMap({
178
+ 'whitespace-pre leading-s text-s focus-outline-none': true,
179
+ 'monospace resize-none p-m block w-full select-text': true,
180
+ 'bg-error-10': this.errors.length > 0,
181
+ 'bg-base': this.errors.length === 0,
182
+ })}
183
+ .value=${this.__formAsString}
184
+ @input=${(evt) => {
185
+ const textarea = evt.currentTarget;
186
+ this.__formAsString = textarea.value;
187
+ }}
188
+ >
189
+ </textarea>
190
+ </div>
191
+
192
+ ${this.data
193
+ ? html `
194
+ <div class="bg-base">
195
+ <ul class="bg-contrast-5 p-xs h-full">
196
+ ${this.__links.map(([curie, link]) => this.__renderLink(curie, link.href, link.title))}
197
+ </ul>
198
+ </div>
199
+ `
200
+ : ''}
201
+ </div>
202
+ </div>
203
+ `;
204
+ }
205
+ get __links() {
206
+ var _a, _b;
207
+ const linksAsEntries = Object.entries((_b = (_a = this.data) === null || _a === void 0 ? void 0 : _a._links) !== null && _b !== void 0 ? _b : {});
208
+ const relevantLinks = linksAsEntries.filter(([curie, link]) => curie !== 'self' && !Array.isArray(link) && !link.templated);
209
+ try {
210
+ relevantLinks.sort(([curie1], [curie2]) => curie1.localeCompare(curie2, this.lang));
211
+ }
212
+ catch (_c) {
213
+ relevantLinks.sort(([curie1], [curie2]) => curie1.localeCompare(curie2));
214
+ }
215
+ return relevantLinks;
216
+ }
217
+ get __formAsString() {
218
+ const form = this.form;
219
+ const validValue = form[ValidValueSymbol];
220
+ const invalidValue = form[InvalidValueSymbol];
221
+ if (typeof invalidValue === 'string')
222
+ return invalidValue;
223
+ if (typeof validValue === 'string')
224
+ return validValue;
225
+ return JSON.stringify(form, (key, value) => (key.startsWith('_') ? undefined : value), 2);
226
+ }
227
+ set __formAsString(newValue) {
228
+ this.undo();
229
+ try {
230
+ const parsedNewValue = JSON.parse(newValue);
231
+ if (typeof parsedNewValue === 'object')
232
+ this.edit(parsedNewValue);
233
+ this.edit({ [ValidValueSymbol]: newValue });
234
+ }
235
+ catch (_a) {
236
+ this.edit({ [InvalidValueSymbol]: newValue });
237
+ }
238
+ }
239
+ __renderLink(curie, href, title) {
240
+ return html `
241
+ <li class="m-xs rounded overflow-hidden transition-colors hover-bg-contrast-5">
242
+ <foxy-swipe-actions>
243
+ <button
244
+ class=${classMap({
245
+ 'rounded leading-none space-y-xs block text-left w-full py-s': true,
246
+ 'ring-inset ring-primary-50': true,
247
+ 'focus-outline-none focus-ring-2 ': true,
248
+ })}
249
+ @click=${() => {
250
+ const evt = new CustomEvent('navigate:get', { bubbles: true, detail: href });
251
+ this.dispatchEvent(evt);
252
+ }}
253
+ >
254
+ <div class="flex items-center">
255
+ <div class="flex-1 space-y-xs px-s min-w-0 text-s">
256
+ <div class="truncate font-semibold">${title || href}</div>
257
+ <div class="opacity-75 truncate">${curie}</div>
258
+ </div>
259
+
260
+ <iron-icon
261
+ class="icon-inline text-xl text-tertiary mr-s flex-shrink-0"
262
+ icon="icons:chevron-right"
263
+ >
264
+ </iron-icon>
265
+ </div>
266
+ </button>
267
+
268
+ <div slot="action" class="h-full flex">
269
+ <vaadin-button
270
+ theme="secondary success"
271
+ class="h-full rounded-none"
272
+ @click=${() => {
273
+ const evt = new CustomEvent('navigate:post', { bubbles: true, detail: href });
274
+ this.dispatchEvent(evt);
275
+ }}
276
+ >
277
+ POST
278
+ </vaadin-button>
279
+ </div>
280
+ </foxy-swipe-actions>
281
+ </li>
282
+ `;
283
+ }
284
+ }
285
+ //# 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 textarea::selection {\n background: var(--lumo-contrast-10pct);\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=\"select-none 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 class=${classMap({\n 'ring-inset ring-primary-50 rounded-t-l': true,\n 'focus-outline-none focus-ring-2': true,\n 'rounded-b-l': !this.open,\n })}\n >\n <div\n class=\"flex items-center space-x-s p-s pr-m transition-colors cursor-pointer bg-contrast-5 hover-bg-contrast-10\"\n >\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 <foxy-internal-create-control infer=\"create\" theme=\"tertiary-inline success\">\n </foxy-internal-create-control>\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 <foxy-internal-delete-control infer=\"delete\" theme=\"tertiary-inline error\">\n </foxy-internal-delete-control>\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-pre leading-s text-s focus-outline-none': true,\n 'monospace resize-none p-m block w-full select-text': 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 const linksAsEntries = Object.entries(this.data?._links ?? {});\n const relevantLinks = linksAsEntries.filter(\n ([curie, link]) => curie !== 'self' && !Array.isArray(link) && !(link as any).templated\n );\n\n try {\n relevantLinks.sort(([curie1], [curie2]) => curie1.localeCompare(curie2, this.lang));\n } catch {\n relevantLinks.sort(([curie1], [curie2]) => curie1.localeCompare(curie2));\n }\n\n return relevantLinks;\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,10 @@
1
+ import '@vaadin/vaadin-button';
2
+ import '@polymer/iron-icons';
3
+ import '@polymer/iron-icon';
4
+ import '../../../../internal/InternalDeleteControl/index';
5
+ import '../../../../internal/InternalCreateControl/index';
6
+ import '../../../../internal/InternalForm/index';
7
+ import '../../../CopyToClipboard/index';
8
+ import '../../../SwipeActions/index';
9
+ import { InternalApiBrowserResourceForm as Form } from './InternalApiBrowserResourceForm';
10
+ export { Form as InternalApiBrowserResourceForm };
@@ -0,0 +1,12 @@
1
+ import '@vaadin/vaadin-button';
2
+ import '@polymer/iron-icons';
3
+ import '@polymer/iron-icon';
4
+ import "../../../../internal/InternalDeleteControl/index.js";
5
+ import "../../../../internal/InternalCreateControl/index.js";
6
+ import "../../../../internal/InternalForm/index.js";
7
+ import "../../../CopyToClipboard/index.js";
8
+ import "../../../SwipeActions/index.js";
9
+ import { InternalApiBrowserResourceForm as Form } from "./InternalApiBrowserResourceForm.js";
10
+ customElements.define('foxy-internal-api-browser-resource-form', Form);
11
+ export { Form as InternalApiBrowserResourceForm };
12
+ //# 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,6DAA0D;AAC1D,6DAA0D;AAC1D,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/InternalDeleteControl/index';\nimport '../../../../internal/InternalCreateControl/index';\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"]}
@@ -1,7 +1,7 @@
1
- import { Rels } from '@foxy.io/sdk/customer';
2
- import { Resource } from '@foxy.io/sdk/core';
3
- import { Renderer } from '../../../mixins/configurable';
4
1
  import { AttributeCard } from './AttributeCard';
2
+ import { Rels } from '@foxy.io/sdk/backend';
3
+ import { Renderer } from '../../../mixins/configurable';
4
+ import { Resource } from '@foxy.io/sdk/core';
5
5
  export declare type Data = Resource<Rels.Attribute>;
6
6
  export declare type Templates = {
7
7
  'name:before'?: Renderer<AttributeCard>;
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeCard/types.ts"],"names":[],"mappings":"","sourcesContent":["import { Rels } from '@foxy.io/sdk/customer';\nimport { Resource } from '@foxy.io/sdk/core';\nimport { Renderer } from '../../../mixins/configurable';\nimport { AttributeCard } from './AttributeCard';\n\nexport type Data = Resource<Rels.Attribute>;\nexport type Templates = {\n 'name:before'?: Renderer<AttributeCard>;\n 'name:after'?: Renderer<AttributeCard>;\n 'value:before'?: Renderer<AttributeCard>;\n 'value:after'?: Renderer<AttributeCard>;\n};\n"]}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeCard/types.ts"],"names":[],"mappings":"","sourcesContent":["import { AttributeCard } from './AttributeCard';\nimport { Rels } from '@foxy.io/sdk/backend';\nimport { Renderer } from '../../../mixins/configurable';\nimport { Resource } from '@foxy.io/sdk/core';\n\nexport type Data = Resource<Rels.Attribute>;\nexport type Templates = {\n 'name:before'?: Renderer<AttributeCard>;\n 'name:after'?: Renderer<AttributeCard>;\n 'value:before'?: Renderer<AttributeCard>;\n 'value:after'?: Renderer<AttributeCard>;\n};\n"]}
@@ -196,6 +196,7 @@ export class AttributeForm extends Base {
196
196
  ];
197
197
  }
198
198
  render() {
199
+ var _a, _b;
199
200
  const { hiddenSelector, data, lang, ns } = this;
200
201
  const isBusy = this.in('busy');
201
202
  const isFail = this.in('fail');
@@ -236,7 +237,7 @@ export class AttributeForm extends Base {
236
237
  class="m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l"
237
238
  state=${isFail ? 'error' : isBusy ? 'busy' : 'empty'}
238
239
  lang=${lang}
239
- ns=${ns}
240
+ ns="${ns} ${(_b = (_a = customElements.get('foxy-spinner')) === null || _a === void 0 ? void 0 : _a.defaultNS) !== null && _b !== void 0 ? _b : ''}"
240
241
  >
241
242
  </foxy-spinner>
242
243
  </div>
@@ -1 +1 @@
1
- {"version":3,"file":"AttributeForm.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeForm/AttributeForm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Choice, Group, PropertyTable } from '../../private/index';\nimport { Data, Templates, TextFieldParams } from './types';\nimport { ScopedElementsMap, ScopedElementsMixin } from '@open-wc/scoped-elements';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { ChoiceChangeEvent } from '../../private/events';\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { DialogHideEvent } from '../../private/Dialog/DialogHideEvent';\nimport { InternalConfirmDialog } from '../../internal/InternalConfirmDialog/InternalConfirmDialog';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { NucleonV8N } from '../NucleonElement/types';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\nimport { ifDefined } from 'lit-html/directives/if-defined';\nimport memoize from 'lodash-es/memoize';\n\nconst NS = 'attribute-form';\nconst Base = TranslatableMixin(\n ConfigurableMixin(ThemeableMixin(ScopedElementsMixin(NucleonElement))),\n NS\n);\n\n/**\n * Form element for creating or editing attributes.\n *\n * @slot name:before - **new in v1.4.0**\n * @slot name:after - **new in v1.4.0**\n * @slot value:before - **new in v1.4.0**\n * @slot value:after - **new in v1.4.0**\n * @slot visibility:before - **new in v1.4.0**\n * @slot visibility:after - **new in v1.4.0**\n * @slot timestamps:before - **new in v1.4.0**\n * @slot timestamps:after - **new in v1.4.0**\n * @slot create:before - **new in v1.4.0**\n * @slot create:after - **new in v1.4.0**\n * @slot delete:before - **new in v1.4.0**\n * @slot delete:after - **new in v1.4.0**\n *\n * @element foxy-attribute-form\n * @since 1.2.0\n */\nexport class AttributeForm extends Base<Data> {\n static get scopedElements(): ScopedElementsMap {\n return {\n 'foxy-internal-confirm-dialog': customElements.get('foxy-internal-confirm-dialog'),\n 'foxy-internal-sandbox': customElements.get('foxy-internal-sandbox'),\n 'vaadin-text-field': customElements.get('vaadin-text-field'),\n 'vaadin-text-area': customElements.get('vaadin-text-area'),\n 'x-property-table': PropertyTable,\n 'vaadin-button': customElements.get('vaadin-button'),\n 'x-choice': Choice,\n 'x-group': Group,\n 'foxy-i18n': customElements.get('foxy-i18n'),\n 'foxy-spinner': customElements.get('foxy-spinner'),\n };\n }\n\n static get v8n(): NucleonV8N<Data> {\n return [\n ({ value }) => (value && value.length > 0) || 'value_required',\n ({ value }) => (value && value.length <= 1000) || 'value_too_long',\n ({ name }) => (name && name.length > 0) || 'name_required',\n ({ name }) => (name && name.length <= 500) || 'name_too_long',\n ];\n }\n\n templates: Templates = {};\n\n private static readonly __visibilityOptions = ['private', 'restricted', 'public'] as const;\n\n private readonly __getValidator = memoize((prefix: string) => () => {\n return !this.errors.some(err => err.startsWith(prefix));\n });\n\n private readonly __bindField = memoize((key: keyof Data) => {\n return (evt: CustomEvent) => {\n const target = evt.target as HTMLInputElement;\n this.edit({ [key]: target.value });\n };\n });\n\n private readonly __maybeRenderTextField = ({ field }: TextFieldParams) => {\n const bsid = field.replace(/_/, '-');\n if (this.hiddenSelector.matches(bsid)) return '';\n\n return html`\n <div>\n ${this.renderTemplateOrSlot(`${bsid}:before`)}\n\n <vaadin-text-field\n class=\"w-full\"\n label=${this.t(field).toString()}\n value=${ifDefined(this.form?.[field]?.toString())}\n error-message=${this.__getErrorMessage(field)}\n data-testid=${field}\n .checkValidity=${this.__getValidator(field)}\n ?disabled=${!this.in('idle') || this.disabledSelector.matches(bsid)}\n ?readonly=${this.readonlySelector.matches(bsid)}\n @input=${this.__bindField(field)}\n @keydown=${this.__handleKeyDown}\n >\n </vaadin-text-field>\n\n ${this.renderTemplateOrSlot(`${bsid}:after`)}\n </div>\n `;\n };\n\n private readonly __renderVisibility = () => {\n const { disabledSelector, readonlySelector, form, lang, ns } = this;\n const isBusyOrFailed = !this.in('idle');\n const isDisabled = isBusyOrFailed || disabledSelector.matches('visibility', true);\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('visibility:before')}\n\n <x-group frame>\n <foxy-i18n\n data-testid=\"visibility-label\"\n class=${classMap({ 'text-disabled': isDisabled })}\n lang=${lang}\n slot=\"header\"\n key=\"visibility\"\n ns=${ns}\n >\n </foxy-i18n>\n\n <x-choice\n data-testid=\"visibility\"\n lang=${lang}\n ns=${AttributeForm.defaultNS}\n .items=${AttributeForm.__visibilityOptions}\n .value=${(form?.visibility ?? 'private') as any}\n ?disabled=${isBusyOrFailed || disabledSelector.matches('visibility', true)}\n ?readonly=${readonlySelector.matches('visibility', true)}\n @change=${this.__handleChoiceChange}\n >\n <foxy-i18n slot=\"private-label\" lang=${lang} key=\"visibility_private\" ns=${ns}>\n </foxy-i18n>\n\n <foxy-i18n slot=\"restricted-label\" lang=${lang} key=\"visibility_restricted\" ns=${ns}>\n </foxy-i18n>\n\n <foxy-i18n ns=${ns} lang=${lang} slot=\"public-label\" key=\"visibility_public\">\n </foxy-i18n>\n </x-choice>\n </x-group>\n\n ${this.renderTemplateOrSlot('visibility:after')}\n </div>\n `;\n };\n\n private readonly __renderTimestamps = () => {\n const items = (['date_modified', 'date_created'] as const).map(field => ({\n name: this.t(field),\n value: this.data?.[field]\n ? this.t('date', { value: new Date(this.data[field] as string) })\n : '',\n }));\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('timestamps:before')}\n <x-property-table .items=${items} data-testid=\"timestamps\"></x-property-table>\n ${this.renderTemplateOrSlot('timestamps:after')}\n </div>\n `;\n };\n\n private readonly __renderDelete = () => {\n return html`\n <div>\n ${this.renderTemplateOrSlot('delete:before')}\n\n <vaadin-button\n class=\"w-full\"\n data-testid=\"delete\"\n theme=\"error primary\"\n ?disabled=${!this.in('idle') || this.disabledSelector.matches('delete', true)}\n @click=${this.__handleDeleteClick}\n >\n <foxy-i18n ns=${this.ns} lang=${this.lang} key=\"delete\"></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('delete:after')}\n </div>\n `;\n };\n\n private readonly __renderCreate = () => {\n const isTemplateValid = this.in({ idle: { template: { dirty: 'valid' } } });\n const isSnapshotValid = this.in({ idle: { snapshot: { dirty: 'valid' } } });\n const isValid = isTemplateValid || isSnapshotValid;\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('create:before')}\n\n <vaadin-button\n data-testid=\"create\"\n class=\"w-full\"\n theme=\"success primary\"\n ?disabled=${!this.in('idle') || !isValid || this.disabledSelector.matches('create', true)}\n @click=${() => this.submit()}\n >\n <foxy-i18n ns=${this.ns} lang=${this.lang} key=\"create\"></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('create:after')}\n </div>\n `;\n };\n\n render(): TemplateResult {\n const { hiddenSelector, data, lang, ns } = this;\n const isBusy = this.in('busy');\n const isFail = this.in('fail');\n\n return html`\n <foxy-internal-confirm-dialog\n data-testid=\"confirm\"\n message=\"delete_prompt\"\n confirm=\"delete\"\n cancel=\"cancel\"\n header=\"delete\"\n theme=\"primary error\"\n lang=${lang}\n ns=${ns}\n id=\"confirm\"\n @hide=${this.__handleConfirmHide}\n >\n </foxy-internal-confirm-dialog>\n\n <div class=\"relative\" aria-busy=${this.in('busy')} aria-live=\"polite\">\n <div class=\"grid grid-cols-1 gap-l\">\n ${this.__maybeRenderTextField({ field: 'name' })}\n ${this.__maybeRenderTextField({ field: 'value' })}\n ${hiddenSelector.matches('visibility', true) ? '' : this.__renderVisibility()}\n ${hiddenSelector.matches('timestamps', true) || !data ? '' : this.__renderTimestamps()}\n ${hiddenSelector.matches('delete', true) || !data ? '' : this.__renderDelete()}\n ${hiddenSelector.matches('create', true) || data ? '' : this.__renderCreate()}\n </div>\n\n <div\n data-testid=\"spinner\"\n class=${classMap({\n 'transition duration-500 ease-in-out absolute inset-0 flex': true,\n 'opacity-0 pointer-events-none': !isBusy && !isFail,\n })}\n >\n <foxy-spinner\n layout=\"vertical\"\n class=\"m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l\"\n state=${isFail ? 'error' : isBusy ? 'busy' : 'empty'}\n lang=${lang}\n ns=${ns}\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n this.__bindField.cache.clear?.();\n this.__getValidator.cache.clear?.();\n }\n\n private get __confirmDialog(): InternalConfirmDialog {\n return this.renderRoot.querySelector('#confirm') as InternalConfirmDialog;\n }\n\n private __getErrorMessage(prefix: string) {\n const error = this.errors.find(err => err.startsWith(prefix));\n return error ? this.t(error.replace(prefix, 'v8n')).toString() : '';\n }\n\n private __handleKeyDown(evt: KeyboardEvent) {\n if (evt.key === 'Enter') this.submit();\n }\n\n private __handleChoiceChange(evt: ChoiceChangeEvent) {\n this.edit({ visibility: evt.detail as Data['visibility'] });\n }\n\n private __handleDeleteClick(evt: Event) {\n this.__confirmDialog.show(evt.currentTarget as HTMLElement);\n }\n\n private __handleConfirmHide(evt: DialogHideEvent) {\n if (!evt.detail.cancelled) this.delete();\n }\n}\n"]}
1
+ {"version":3,"file":"AttributeForm.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeForm/AttributeForm.ts"],"names":[],"mappings":"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","sourcesContent":["import { Choice, Group, PropertyTable } from '../../private/index';\nimport { Data, Templates, TextFieldParams } from './types';\nimport { ScopedElementsMap, ScopedElementsMixin } from '@open-wc/scoped-elements';\nimport { TemplateResult, html } from 'lit-html';\n\nimport { ChoiceChangeEvent } from '../../private/events';\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { DialogHideEvent } from '../../private/Dialog/DialogHideEvent';\nimport { InternalConfirmDialog } from '../../internal/InternalConfirmDialog/InternalConfirmDialog';\nimport { NucleonElement } from '../NucleonElement/NucleonElement';\nimport { NucleonV8N } from '../NucleonElement/types';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { classMap } from '../../../utils/class-map';\nimport { ifDefined } from 'lit-html/directives/if-defined';\nimport memoize from 'lodash-es/memoize';\n\nconst NS = 'attribute-form';\nconst Base = TranslatableMixin(\n ConfigurableMixin(ThemeableMixin(ScopedElementsMixin(NucleonElement))),\n NS\n);\n\n/**\n * Form element for creating or editing attributes.\n *\n * @slot name:before - **new in v1.4.0**\n * @slot name:after - **new in v1.4.0**\n * @slot value:before - **new in v1.4.0**\n * @slot value:after - **new in v1.4.0**\n * @slot visibility:before - **new in v1.4.0**\n * @slot visibility:after - **new in v1.4.0**\n * @slot timestamps:before - **new in v1.4.0**\n * @slot timestamps:after - **new in v1.4.0**\n * @slot create:before - **new in v1.4.0**\n * @slot create:after - **new in v1.4.0**\n * @slot delete:before - **new in v1.4.0**\n * @slot delete:after - **new in v1.4.0**\n *\n * @element foxy-attribute-form\n * @since 1.2.0\n */\nexport class AttributeForm extends Base<Data> {\n static get scopedElements(): ScopedElementsMap {\n return {\n 'foxy-internal-confirm-dialog': customElements.get('foxy-internal-confirm-dialog'),\n 'foxy-internal-sandbox': customElements.get('foxy-internal-sandbox'),\n 'vaadin-text-field': customElements.get('vaadin-text-field'),\n 'vaadin-text-area': customElements.get('vaadin-text-area'),\n 'x-property-table': PropertyTable,\n 'vaadin-button': customElements.get('vaadin-button'),\n 'x-choice': Choice,\n 'x-group': Group,\n 'foxy-i18n': customElements.get('foxy-i18n'),\n 'foxy-spinner': customElements.get('foxy-spinner'),\n };\n }\n\n static get v8n(): NucleonV8N<Data> {\n return [\n ({ value }) => (value && value.length > 0) || 'value_required',\n ({ value }) => (value && value.length <= 1000) || 'value_too_long',\n ({ name }) => (name && name.length > 0) || 'name_required',\n ({ name }) => (name && name.length <= 500) || 'name_too_long',\n ];\n }\n\n templates: Templates = {};\n\n private static readonly __visibilityOptions = ['private', 'restricted', 'public'] as const;\n\n private readonly __getValidator = memoize((prefix: string) => () => {\n return !this.errors.some(err => err.startsWith(prefix));\n });\n\n private readonly __bindField = memoize((key: keyof Data) => {\n return (evt: CustomEvent) => {\n const target = evt.target as HTMLInputElement;\n this.edit({ [key]: target.value });\n };\n });\n\n private readonly __maybeRenderTextField = ({ field }: TextFieldParams) => {\n const bsid = field.replace(/_/, '-');\n if (this.hiddenSelector.matches(bsid)) return '';\n\n return html`\n <div>\n ${this.renderTemplateOrSlot(`${bsid}:before`)}\n\n <vaadin-text-field\n class=\"w-full\"\n label=${this.t(field).toString()}\n value=${ifDefined(this.form?.[field]?.toString())}\n error-message=${this.__getErrorMessage(field)}\n data-testid=${field}\n .checkValidity=${this.__getValidator(field)}\n ?disabled=${!this.in('idle') || this.disabledSelector.matches(bsid)}\n ?readonly=${this.readonlySelector.matches(bsid)}\n @input=${this.__bindField(field)}\n @keydown=${this.__handleKeyDown}\n >\n </vaadin-text-field>\n\n ${this.renderTemplateOrSlot(`${bsid}:after`)}\n </div>\n `;\n };\n\n private readonly __renderVisibility = () => {\n const { disabledSelector, readonlySelector, form, lang, ns } = this;\n const isBusyOrFailed = !this.in('idle');\n const isDisabled = isBusyOrFailed || disabledSelector.matches('visibility', true);\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('visibility:before')}\n\n <x-group frame>\n <foxy-i18n\n data-testid=\"visibility-label\"\n class=${classMap({ 'text-disabled': isDisabled })}\n lang=${lang}\n slot=\"header\"\n key=\"visibility\"\n ns=${ns}\n >\n </foxy-i18n>\n\n <x-choice\n data-testid=\"visibility\"\n lang=${lang}\n ns=${AttributeForm.defaultNS}\n .items=${AttributeForm.__visibilityOptions}\n .value=${(form?.visibility ?? 'private') as any}\n ?disabled=${isBusyOrFailed || disabledSelector.matches('visibility', true)}\n ?readonly=${readonlySelector.matches('visibility', true)}\n @change=${this.__handleChoiceChange}\n >\n <foxy-i18n slot=\"private-label\" lang=${lang} key=\"visibility_private\" ns=${ns}>\n </foxy-i18n>\n\n <foxy-i18n slot=\"restricted-label\" lang=${lang} key=\"visibility_restricted\" ns=${ns}>\n </foxy-i18n>\n\n <foxy-i18n ns=${ns} lang=${lang} slot=\"public-label\" key=\"visibility_public\">\n </foxy-i18n>\n </x-choice>\n </x-group>\n\n ${this.renderTemplateOrSlot('visibility:after')}\n </div>\n `;\n };\n\n private readonly __renderTimestamps = () => {\n const items = (['date_modified', 'date_created'] as const).map(field => ({\n name: this.t(field),\n value: this.data?.[field]\n ? this.t('date', { value: new Date(this.data[field] as string) })\n : '',\n }));\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('timestamps:before')}\n <x-property-table .items=${items} data-testid=\"timestamps\"></x-property-table>\n ${this.renderTemplateOrSlot('timestamps:after')}\n </div>\n `;\n };\n\n private readonly __renderDelete = () => {\n return html`\n <div>\n ${this.renderTemplateOrSlot('delete:before')}\n\n <vaadin-button\n class=\"w-full\"\n data-testid=\"delete\"\n theme=\"error primary\"\n ?disabled=${!this.in('idle') || this.disabledSelector.matches('delete', true)}\n @click=${this.__handleDeleteClick}\n >\n <foxy-i18n ns=${this.ns} lang=${this.lang} key=\"delete\"></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('delete:after')}\n </div>\n `;\n };\n\n private readonly __renderCreate = () => {\n const isTemplateValid = this.in({ idle: { template: { dirty: 'valid' } } });\n const isSnapshotValid = this.in({ idle: { snapshot: { dirty: 'valid' } } });\n const isValid = isTemplateValid || isSnapshotValid;\n\n return html`\n <div>\n ${this.renderTemplateOrSlot('create:before')}\n\n <vaadin-button\n data-testid=\"create\"\n class=\"w-full\"\n theme=\"success primary\"\n ?disabled=${!this.in('idle') || !isValid || this.disabledSelector.matches('create', true)}\n @click=${() => this.submit()}\n >\n <foxy-i18n ns=${this.ns} lang=${this.lang} key=\"create\"></foxy-i18n>\n </vaadin-button>\n\n ${this.renderTemplateOrSlot('create:after')}\n </div>\n `;\n };\n\n render(): TemplateResult {\n const { hiddenSelector, data, lang, ns } = this;\n const isBusy = this.in('busy');\n const isFail = this.in('fail');\n\n return html`\n <foxy-internal-confirm-dialog\n data-testid=\"confirm\"\n message=\"delete_prompt\"\n confirm=\"delete\"\n cancel=\"cancel\"\n header=\"delete\"\n theme=\"primary error\"\n lang=${lang}\n ns=${ns}\n id=\"confirm\"\n @hide=${this.__handleConfirmHide}\n >\n </foxy-internal-confirm-dialog>\n\n <div class=\"relative\" aria-busy=${this.in('busy')} aria-live=\"polite\">\n <div class=\"grid grid-cols-1 gap-l\">\n ${this.__maybeRenderTextField({ field: 'name' })}\n ${this.__maybeRenderTextField({ field: 'value' })}\n ${hiddenSelector.matches('visibility', true) ? '' : this.__renderVisibility()}\n ${hiddenSelector.matches('timestamps', true) || !data ? '' : this.__renderTimestamps()}\n ${hiddenSelector.matches('delete', true) || !data ? '' : this.__renderDelete()}\n ${hiddenSelector.matches('create', true) || data ? '' : this.__renderCreate()}\n </div>\n\n <div\n data-testid=\"spinner\"\n class=${classMap({\n 'transition duration-500 ease-in-out absolute inset-0 flex': true,\n 'opacity-0 pointer-events-none': !isBusy && !isFail,\n })}\n >\n <foxy-spinner\n layout=\"vertical\"\n class=\"m-auto p-m bg-base shadow-xs rounded-t-l rounded-b-l\"\n state=${isFail ? 'error' : isBusy ? 'busy' : 'empty'}\n lang=${lang}\n ns=\"${ns} ${customElements.get('foxy-spinner')?.defaultNS ?? ''}\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n\n disconnectedCallback(): void {\n super.disconnectedCallback();\n this.__bindField.cache.clear?.();\n this.__getValidator.cache.clear?.();\n }\n\n private get __confirmDialog(): InternalConfirmDialog {\n return this.renderRoot.querySelector('#confirm') as InternalConfirmDialog;\n }\n\n private __getErrorMessage(prefix: string) {\n const error = this.errors.find(err => err.startsWith(prefix));\n return error ? this.t(error.replace(prefix, 'v8n')).toString() : '';\n }\n\n private __handleKeyDown(evt: KeyboardEvent) {\n if (evt.key === 'Enter') this.submit();\n }\n\n private __handleChoiceChange(evt: ChoiceChangeEvent) {\n this.edit({ visibility: evt.detail as Data['visibility'] });\n }\n\n private __handleDeleteClick(evt: Event) {\n this.__confirmDialog.show(evt.currentTarget as HTMLElement);\n }\n\n private __handleConfirmHide(evt: DialogHideEvent) {\n if (!evt.detail.cancelled) this.delete();\n }\n}\n"]}
@@ -1,7 +1,7 @@
1
- import { Rels } from '@foxy.io/sdk/customer';
2
- import { Resource } from '@foxy.io/sdk/core';
3
- import { Renderer } from '../../../mixins/configurable';
4
1
  import { AttributeForm } from './AttributeForm';
2
+ import { Rels } from '@foxy.io/sdk/backend';
3
+ import { Renderer } from '../../../mixins/configurable';
4
+ import { Resource } from '@foxy.io/sdk/core';
5
5
  export declare type Data = Resource<Rels.Attribute>;
6
6
  export declare type TextFieldParams = {
7
7
  field: keyof Data;
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeForm/types.ts"],"names":[],"mappings":"","sourcesContent":["import { Rels } from '@foxy.io/sdk/customer';\nimport { Resource } from '@foxy.io/sdk/core';\nimport { Renderer } from '../../../mixins/configurable';\nimport { AttributeForm } from './AttributeForm';\n\nexport type Data = Resource<Rels.Attribute>;\nexport type TextFieldParams = { field: keyof Data };\nexport type Templates = {\n 'name:before'?: Renderer<AttributeForm>;\n 'name:after'?: Renderer<AttributeForm>;\n 'value:before'?: Renderer<AttributeForm>;\n 'value:after'?: Renderer<AttributeForm>;\n 'visibility:before'?: Renderer<AttributeForm>;\n 'visibility:after'?: Renderer<AttributeForm>;\n 'timestamps:before'?: Renderer<AttributeForm>;\n 'timestamps:after'?: Renderer<AttributeForm>;\n 'delete:before'?: Renderer<AttributeForm>;\n 'delete:after'?: Renderer<AttributeForm>;\n 'create:before'?: Renderer<AttributeForm>;\n 'create:after'?: Renderer<AttributeForm>;\n};\n"]}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/elements/public/AttributeForm/types.ts"],"names":[],"mappings":"","sourcesContent":["import { AttributeForm } from './AttributeForm';\nimport { Rels } from '@foxy.io/sdk/backend';\nimport { Renderer } from '../../../mixins/configurable';\nimport { Resource } from '@foxy.io/sdk/core';\n\nexport type Data = Resource<Rels.Attribute>;\nexport type TextFieldParams = { field: keyof Data };\nexport type Templates = {\n 'name:before'?: Renderer<AttributeForm>;\n 'name:after'?: Renderer<AttributeForm>;\n 'value:before'?: Renderer<AttributeForm>;\n 'value:after'?: Renderer<AttributeForm>;\n 'visibility:before'?: Renderer<AttributeForm>;\n 'visibility:after'?: Renderer<AttributeForm>;\n 'timestamps:before'?: Renderer<AttributeForm>;\n 'timestamps:after'?: Renderer<AttributeForm>;\n 'delete:before'?: Renderer<AttributeForm>;\n 'delete:after'?: Renderer<AttributeForm>;\n 'create:before'?: Renderer<AttributeForm>;\n 'create:after'?: Renderer<AttributeForm>;\n};\n"]}
@@ -1,19 +1,20 @@
1
1
  import { ExtractItem, ItemRenderer, Page } from './types';
2
2
  import { PropertyDeclarations, TemplateResult } from 'lit-element';
3
3
  import { NucleonElement } from '../NucleonElement/NucleonElement';
4
- declare const CollectionPage_base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost>;
4
+ declare const Base: typeof NucleonElement & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
5
+ defaultNS: string;
6
+ } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost>;
5
7
  /**
6
8
  * Renders an element for each resource in a collection page.
7
9
  *
8
10
  * @element foxy-collection-page
9
11
  * @since 1.1.0
10
12
  */
11
- export declare class CollectionPage<TPage extends Page> extends CollectionPage_base<TPage> {
13
+ export declare class CollectionPage<TPage extends Page> extends Base<TPage> {
12
14
  /** @readonly */
13
15
  static get properties(): PropertyDeclarations;
14
16
  /** Spread directive argument from `@open-wc/lit-helpers` (properties, event listeners and attributes you'd like to pass to the item element). */
15
17
  props: Record<string, unknown>;
16
- ns: string;
17
18
  private __pageFetchEventHandler;
18
19
  private __renderItem;
19
20
  private __item;
@@ -1,21 +1,22 @@
1
1
  import { html } from 'lit-element';
2
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
2
3
  import { ConfigurableMixin } from "../../../mixins/configurable.js";
3
4
  import { FetchEvent } from "../NucleonElement/FetchEvent.js";
4
5
  import { NucleonElement } from "../NucleonElement/NucleonElement.js";
5
6
  import { repeat } from 'lit-html/directives/repeat';
6
7
  import { spread } from '@open-wc/lit-helpers';
8
+ const Base = ConfigurableMixin(TranslatableMixin(NucleonElement));
7
9
  /**
8
10
  * Renders an element for each resource in a collection page.
9
11
  *
10
12
  * @element foxy-collection-page
11
13
  * @since 1.1.0
12
14
  */
13
- export class CollectionPage extends ConfigurableMixin(NucleonElement) {
15
+ export class CollectionPage extends Base {
14
16
  constructor() {
15
17
  super();
16
18
  /** Spread directive argument from `@open-wc/lit-helpers` (properties, event listeners and attributes you'd like to pass to the item element). */
17
19
  this.props = {};
18
- this.ns = '';
19
20
  this.__pageFetchEventHandler = (evt) => this.__handlePageFetchEvent(evt);
20
21
  this.item = 'foxy-null';
21
22
  }
@@ -25,7 +26,6 @@ export class CollectionPage extends ConfigurableMixin(NucleonElement) {
25
26
  ...super.properties,
26
27
  props: { type: Object },
27
28
  item: { type: String },
28
- ns: { type: String },
29
29
  };
30
30
  }
31
31
  /**
@@ -50,6 +50,7 @@ export class CollectionPage extends ConfigurableMixin(NucleonElement) {
50
50
  readonlycontrols=\${ctx.readonlyControls.toString()}
51
51
  hiddencontrols=\${ctx.hiddenControls.toString()}
52
52
  data-testclass="items"
53
+ related=\${JSON.stringify(ctx.related)}
53
54
  parent=\${ctx.parent}
54
55
  group=\${ctx.group}
55
56
  href=\${ctx.href}
@@ -102,6 +103,7 @@ export class CollectionPage extends ConfigurableMixin(NucleonElement) {
102
103
  disabled: this.disabled,
103
104
  readonly: this.readonly,
104
105
  previous: (_c = (_b = items[index - 1]) === null || _b === void 0 ? void 0 : _b.data) !== null && _c !== void 0 ? _c : null,
106
+ related: this.related,
105
107
  hidden: this.hidden,
106
108
  parent: this.href,
107
109
  spread: spread,