@foxy.io/elements 1.16.0-beta.8 → 1.17.0

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 (314) hide show
  1. package/dist/cdn/foxy-access-recovery-form.js +1 -1
  2. package/dist/cdn/foxy-address-card.js +2 -2
  3. package/dist/cdn/foxy-address-form.js +1 -1
  4. package/dist/cdn/foxy-api-browser.js +3 -3
  5. package/dist/cdn/foxy-applied-tax-card.js +1 -1
  6. package/dist/cdn/foxy-attribute-card.js +1 -1
  7. package/dist/cdn/foxy-attribute-form.js +1 -1
  8. package/dist/cdn/foxy-cancellation-form.js +1 -1
  9. package/dist/cdn/foxy-collection-page.js +1 -1
  10. package/dist/cdn/foxy-collection-pages.js +1 -1
  11. package/dist/cdn/foxy-copy-to-clipboard.js +1 -1
  12. package/dist/cdn/foxy-coupon-card.js +1 -1
  13. package/dist/cdn/foxy-coupon-code-form.js +1 -1
  14. package/dist/cdn/foxy-coupon-codes-form.js +1 -1
  15. package/dist/cdn/foxy-coupon-detail-card.js +1 -1
  16. package/dist/cdn/foxy-coupon-form.js +1 -1
  17. package/dist/cdn/foxy-custom-field-card.js +1 -1
  18. package/dist/cdn/foxy-custom-field-form.js +1 -1
  19. package/dist/cdn/foxy-customer-api.js +1 -1
  20. package/dist/cdn/foxy-customer-card.js +1 -1
  21. package/dist/cdn/foxy-customer-form.js +1 -1
  22. package/dist/cdn/foxy-customer-portal-settings.js +1 -1
  23. package/dist/cdn/foxy-customer-portal.js +1 -1
  24. package/dist/cdn/foxy-customer.js +1 -1
  25. package/dist/cdn/foxy-customers-table.js +1 -1
  26. package/dist/cdn/foxy-discount-builder.js +1 -1
  27. package/dist/cdn/foxy-discount-card.js +1 -1
  28. package/dist/cdn/foxy-discount-detail-card.js +1 -1
  29. package/dist/cdn/foxy-donation.js +1 -1
  30. package/dist/cdn/foxy-email-template-form.js +1 -1
  31. package/dist/cdn/foxy-error-entry-card.js +1 -1
  32. package/dist/cdn/foxy-form-dialog.js +1 -1
  33. package/dist/cdn/foxy-generate-codes-form.js +1 -1
  34. package/dist/cdn/foxy-gift-card-card.js +1 -1
  35. package/dist/cdn/foxy-gift-card-code-form.js +1 -1
  36. package/dist/cdn/foxy-gift-card-codes-form.js +1 -1
  37. package/dist/cdn/foxy-gift-card-form.js +1 -1
  38. package/dist/cdn/foxy-i18n.js +1 -1
  39. package/dist/cdn/foxy-item-card.js +1 -1
  40. package/dist/cdn/foxy-item-form.js +1 -1
  41. package/dist/cdn/foxy-item-option-card.js +1 -1
  42. package/dist/cdn/foxy-item-option-form.js +1 -1
  43. package/dist/cdn/foxy-items-form.js +1 -1
  44. package/dist/cdn/foxy-nucleon-element.js +1 -1
  45. package/dist/cdn/foxy-pagination.js +1 -1
  46. package/dist/cdn/foxy-payment-card.js +1 -1
  47. package/dist/cdn/foxy-payment-method-card.js +1 -1
  48. package/dist/cdn/foxy-query-builder.js +1 -1
  49. package/dist/cdn/foxy-report-form.js +9 -9
  50. package/dist/cdn/foxy-reports-table.js +3 -3
  51. package/dist/cdn/foxy-shipment-card.js +3 -7
  52. package/dist/cdn/foxy-sign-in-form.js +1 -1
  53. package/dist/cdn/foxy-spinner.js +1 -1
  54. package/dist/cdn/foxy-subscription-card.js +1 -1
  55. package/dist/cdn/foxy-subscription-form.js +4 -4
  56. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  57. package/dist/cdn/foxy-table.js +1 -1
  58. package/dist/cdn/foxy-tax-card.js +1 -1
  59. package/dist/cdn/foxy-tax-form.js +1 -1
  60. package/dist/cdn/foxy-template-config-form.js +1 -1
  61. package/dist/cdn/foxy-template-form.js +1 -1
  62. package/dist/cdn/foxy-transaction-card.js +1 -1
  63. package/dist/cdn/foxy-transaction.js +1 -64
  64. package/dist/cdn/foxy-transactions-table.js +1 -1
  65. package/dist/cdn/foxy-user-form.js +1 -1
  66. package/dist/cdn/foxy-users-table.js +1 -1
  67. package/dist/cdn/foxy-webhook-card.js +1 -1
  68. package/dist/cdn/foxy-webhook-form.js +7 -156
  69. package/dist/cdn/foxy-webhook-log-card.js +1 -1
  70. package/dist/cdn/foxy-webhook-status-card.js +1 -1
  71. package/dist/cdn/{shared-3b318016.js → shared-195fd5af.js} +1 -1
  72. package/dist/cdn/{shared-f0ba30e8.js → shared-1bbd9b73.js} +1 -1
  73. package/dist/cdn/{shared-4764b995.js → shared-2188d5f7.js} +4 -4
  74. package/dist/cdn/{shared-40315eea.js → shared-26ce8d23.js} +1 -1
  75. package/dist/cdn/{shared-15d04c73.js → shared-2bdd4f74.js} +1 -1
  76. package/dist/cdn/{shared-f2a561f7.js → shared-31c43743.js} +1 -1
  77. package/dist/cdn/{shared-e9967127.js → shared-322e7efb.js} +5 -5
  78. package/dist/cdn/{shared-95b0cdf1.js → shared-39f2c345.js} +1 -1
  79. package/dist/cdn/{shared-eb1d4a32.js → shared-3b2dedf9.js} +1 -1
  80. package/dist/cdn/shared-45feee83.js +1 -0
  81. package/dist/cdn/{shared-addf6302.js → shared-4e201e09.js} +1 -1
  82. package/dist/cdn/{shared-5cb2c769.js → shared-5c3a88d2.js} +1 -1
  83. package/dist/cdn/{shared-855a1983.js → shared-62169210.js} +2 -2
  84. package/dist/cdn/{shared-3e14ffe1.js → shared-63685d2e.js} +2 -2
  85. package/dist/cdn/{shared-78adab3d.js → shared-6d104622.js} +1 -1
  86. package/dist/cdn/{shared-e6be392d.js → shared-7474af47.js} +1 -1
  87. package/dist/cdn/shared-7c612495.js +1 -0
  88. package/dist/cdn/shared-7c8bb60c.js +1 -0
  89. package/dist/cdn/shared-8d4fef94.js +1 -0
  90. package/dist/cdn/{shared-c0deb4cf.js → shared-8d937ae4.js} +3 -3
  91. package/dist/cdn/{shared-c6ed5394.js → shared-8e9a3bbb.js} +1 -1
  92. package/dist/cdn/shared-92327224.js +15 -0
  93. package/dist/cdn/shared-98497473.js +1 -0
  94. package/dist/cdn/{shared-107acd1f.js → shared-a052131e.js} +2 -2
  95. package/dist/cdn/{shared-e0a54dfc.js → shared-a0836fa5.js} +1 -1
  96. package/dist/cdn/{shared-d08fcc29.js → shared-a5e52b8f.js} +3 -3
  97. package/dist/cdn/shared-ac44429d.js +1 -0
  98. package/dist/cdn/{shared-abfe9262.js → shared-ae415a98.js} +2 -2
  99. package/dist/cdn/shared-b3df4f38.js +1 -0
  100. package/dist/cdn/{shared-85d4b53e.js → shared-baf79b0b.js} +1 -1
  101. package/dist/cdn/{shared-cea659c8.js → shared-bb686fc6.js} +1 -1
  102. package/dist/cdn/{shared-3474279e.js → shared-bf6fb415.js} +1 -1
  103. package/dist/cdn/shared-c309e0ef.js +1 -0
  104. package/dist/cdn/{shared-73cfd096.js → shared-c5c60417.js} +1 -1
  105. package/dist/cdn/{shared-e21c712d.js → shared-c8677ba3.js} +1 -1
  106. package/dist/cdn/{shared-c9757355.js → shared-c89ba319.js} +1 -1
  107. package/dist/cdn/{shared-8c41299f.js → shared-d28ac9dc.js} +1 -1
  108. package/dist/cdn/{shared-9e0387e6.js → shared-d699348f.js} +2 -2
  109. package/dist/cdn/shared-dc1c6edd.js +1 -0
  110. package/dist/cdn/{shared-78a2c66f.js → shared-dc23b751.js} +1 -1
  111. package/dist/cdn/shared-dc3ffd38.js +1 -0
  112. package/dist/cdn/{shared-5e228fca.js → shared-dd6d3c18.js} +1 -1
  113. package/dist/cdn/{shared-21f6c806.js → shared-dda2a74d.js} +1 -1
  114. package/dist/cdn/{shared-40c5712e.js → shared-e9a4a204.js} +1 -1
  115. package/dist/cdn/{shared-a2f5defb.js → shared-f1317609.js} +1 -1
  116. package/dist/cdn/{shared-af60799b.js → shared-f84686a8.js} +4 -4
  117. package/dist/cdn/{shared-2eee69db.js → shared-fadcb2e1.js} +0 -0
  118. package/dist/cdn/translations/api-browser/en.json +3 -0
  119. package/dist/cdn/translations/customer-portal/se.json +223 -0
  120. package/dist/cdn/translations/discount-builder/en.json +14 -0
  121. package/dist/cdn/translations/item-form/en.json +24 -0
  122. package/dist/cdn/translations/transaction/en.json +28 -4
  123. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.d.ts +1 -1
  124. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.js +1 -1
  125. package/dist/elements/internal/InternalAsyncComboBoxControl/InternalAsyncComboBoxControl.js.map +1 -1
  126. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.d.ts +2 -1
  127. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.js +11 -2
  128. package/dist/elements/internal/InternalAsyncDetailsControl/InternalAsyncDetailsControl.js.map +1 -1
  129. package/dist/elements/internal/InternalAsyncDetailsControl/index.d.ts +1 -0
  130. package/dist/elements/internal/InternalAsyncDetailsControl/index.js +1 -0
  131. package/dist/elements/internal/InternalAsyncDetailsControl/index.js.map +1 -1
  132. package/dist/elements/internal/InternalCard/InternalCard.d.ts +1 -1
  133. package/dist/elements/internal/InternalCard/InternalCard.js +1 -1
  134. package/dist/elements/internal/InternalCard/InternalCard.js.map +1 -1
  135. package/dist/elements/internal/InternalControl/InternalControl.d.ts +22 -2
  136. package/dist/elements/internal/InternalControl/InternalControl.js +29 -8
  137. package/dist/elements/internal/InternalControl/InternalControl.js.map +1 -1
  138. package/dist/elements/internal/InternalControl/index.d.ts +2 -0
  139. package/dist/elements/internal/InternalControl/index.js +2 -0
  140. package/dist/elements/internal/InternalControl/index.js.map +1 -1
  141. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.d.ts +1 -1
  142. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.js +1 -1
  143. package/dist/elements/internal/InternalCreateControl/InternalCreateControl.js.map +1 -1
  144. package/dist/elements/internal/InternalCreateControl/index.d.ts +2 -1
  145. package/dist/elements/internal/InternalCreateControl/index.js +2 -1
  146. package/dist/elements/internal/InternalCreateControl/index.js.map +1 -1
  147. package/dist/elements/internal/InternalDateControl/InternalDateControl.d.ts +1 -1
  148. package/dist/elements/internal/InternalDateControl/InternalDateControl.js +1 -1
  149. package/dist/elements/internal/InternalDateControl/InternalDateControl.js.map +1 -1
  150. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.d.ts +8 -1
  151. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.js +10 -5
  152. package/dist/elements/internal/InternalDeleteControl/InternalDeleteControl.js.map +1 -1
  153. package/dist/elements/internal/InternalDeleteControl/index.d.ts +3 -2
  154. package/dist/elements/internal/InternalDeleteControl/index.js +3 -2
  155. package/dist/elements/internal/InternalDeleteControl/index.js.map +1 -1
  156. package/dist/elements/internal/InternalDetails/InternalDetails.d.ts +1 -1
  157. package/dist/elements/internal/InternalDetails/InternalDetails.js +1 -1
  158. package/dist/elements/internal/InternalDetails/InternalDetails.js.map +1 -1
  159. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.d.ts +52 -0
  160. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.js +82 -7
  161. package/dist/elements/internal/InternalEditableControl/InternalEditableControl.js.map +1 -1
  162. package/dist/elements/internal/InternalForm/InternalForm.d.ts +16 -0
  163. package/dist/elements/internal/InternalForm/InternalForm.js +17 -0
  164. package/dist/elements/internal/InternalForm/InternalForm.js.map +1 -1
  165. package/dist/elements/internal/InternalForm/index.d.ts +2 -2
  166. package/dist/elements/internal/InternalForm/index.js +2 -2
  167. package/dist/elements/internal/InternalForm/index.js.map +1 -1
  168. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.d.ts +1 -1
  169. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.js +1 -1
  170. package/dist/elements/internal/InternalFrequencyControl/InternalFrequencyControl.js.map +1 -1
  171. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.d.ts +1 -1
  172. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.js +1 -1
  173. package/dist/elements/internal/InternalIntegerControl/InternalIntegerControl.js.map +1 -1
  174. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.d.ts +1 -1
  175. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js +1 -1
  176. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js.map +1 -1
  177. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.d.ts +1 -1
  178. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js +1 -1
  179. package/dist/elements/internal/InternalRadioGroupControl/InternalRadioGroupControl.js.map +1 -1
  180. package/dist/elements/internal/InternalTextControl/InternalTextControl.d.ts +1 -1
  181. package/dist/elements/internal/InternalTextControl/InternalTextControl.js +1 -1
  182. package/dist/elements/internal/InternalTextControl/InternalTextControl.js.map +1 -1
  183. package/dist/elements/internal/InternalTimestampsControl/InternalTimestampsControl.d.ts +14 -0
  184. package/dist/elements/internal/{InternalForm/internal/InternalTimestampsControl → InternalTimestampsControl}/InternalTimestampsControl.js +12 -11
  185. package/dist/elements/internal/InternalTimestampsControl/InternalTimestampsControl.js.map +1 -0
  186. package/dist/elements/internal/{InternalForm/internal/InternalTimestampsControl → InternalTimestampsControl}/index.d.ts +2 -0
  187. package/dist/elements/internal/{InternalForm/internal/InternalTimestampsControl → InternalTimestampsControl}/index.js +2 -0
  188. package/dist/elements/internal/InternalTimestampsControl/index.js.map +1 -0
  189. package/dist/elements/public/ApiBrowser/ApiBrowser.d.ts +1 -1
  190. package/dist/elements/public/ApiBrowser/ApiBrowser.js +12 -6
  191. package/dist/elements/public/ApiBrowser/ApiBrowser.js.map +1 -1
  192. package/dist/elements/public/ApiBrowser/index.d.ts +1 -0
  193. package/dist/elements/public/ApiBrowser/index.js +1 -0
  194. package/dist/elements/public/ApiBrowser/index.js.map +1 -1
  195. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.d.ts +7 -0
  196. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js +15 -3
  197. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/InternalApiBrowserResourceForm.js.map +1 -1
  198. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.d.ts +1 -0
  199. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js +1 -0
  200. package/dist/elements/public/ApiBrowser/internal/InternalApiBrowserResourceForm/index.js.map +1 -1
  201. package/dist/elements/public/CopyToClipboard/CopyToClipboard.d.ts +9 -1
  202. package/dist/elements/public/CopyToClipboard/CopyToClipboard.js +11 -2
  203. package/dist/elements/public/CopyToClipboard/CopyToClipboard.js.map +1 -1
  204. package/dist/elements/public/CopyToClipboard/index.d.ts +1 -0
  205. package/dist/elements/public/CopyToClipboard/index.js +1 -0
  206. package/dist/elements/public/CopyToClipboard/index.js.map +1 -1
  207. package/dist/elements/public/CouponForm/CouponForm.js +1 -0
  208. package/dist/elements/public/CouponForm/CouponForm.js.map +1 -1
  209. package/dist/elements/public/DiscountBuilder/DiscountBuilder.d.ts +21 -9
  210. package/dist/elements/public/DiscountBuilder/DiscountBuilder.js +33 -30
  211. package/dist/elements/public/DiscountBuilder/DiscountBuilder.js.map +1 -1
  212. package/dist/elements/public/DiscountBuilder/index.d.ts +1 -0
  213. package/dist/elements/public/DiscountBuilder/index.js +1 -0
  214. package/dist/elements/public/DiscountBuilder/index.js.map +1 -1
  215. package/dist/elements/public/DiscountBuilder/types.d.ts +32 -0
  216. package/dist/elements/public/DiscountBuilder/types.js +2 -0
  217. package/dist/elements/public/DiscountBuilder/types.js.map +1 -0
  218. package/dist/elements/public/I18n/format/discount.js +1 -0
  219. package/dist/elements/public/I18n/format/discount.js.map +1 -1
  220. package/dist/elements/public/ItemCard/ItemCard.d.ts +6 -0
  221. package/dist/elements/public/ItemCard/ItemCard.js +10 -1
  222. package/dist/elements/public/ItemCard/ItemCard.js.map +1 -1
  223. package/dist/elements/public/ItemForm/ItemForm.d.ts +45 -3
  224. package/dist/elements/public/ItemForm/ItemForm.js +50 -8
  225. package/dist/elements/public/ItemForm/ItemForm.js.map +1 -1
  226. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js +1 -1
  227. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/InternalItemFormCartControl.js.map +1 -1
  228. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.d.ts +2 -1
  229. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js +2 -1
  230. package/dist/elements/public/ItemForm/internal/InternalItemFormCartControl/index.js.map +1 -1
  231. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js +3 -3
  232. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/InternalItemFormInventoryControl.js.map +1 -1
  233. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.d.ts +2 -1
  234. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js +2 -1
  235. package/dist/elements/public/ItemForm/internal/InternalItemFormInventoryControl/index.js.map +1 -1
  236. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js +16 -6
  237. package/dist/elements/public/ItemForm/internal/InternalItemFormLineItemDiscountControl/InternalItemFormLineItemDiscountControl.js.map +1 -1
  238. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js +3 -3
  239. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/InternalItemFormShippingControl.js.map +1 -1
  240. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.d.ts +2 -1
  241. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js +2 -1
  242. package/dist/elements/public/ItemForm/internal/InternalItemFormShippingControl/index.js.map +1 -1
  243. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js +3 -8
  244. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/InternalItemFormSubscriptionControl.js.map +1 -1
  245. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.d.ts +2 -1
  246. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js +2 -1
  247. package/dist/elements/public/ItemForm/internal/InternalItemFormSubscriptionControl/index.js.map +1 -1
  248. package/dist/elements/public/ItemOptionForm/ItemOptionForm.d.ts +18 -0
  249. package/dist/elements/public/ItemOptionForm/ItemOptionForm.js +18 -0
  250. package/dist/elements/public/ItemOptionForm/ItemOptionForm.js.map +1 -1
  251. package/dist/elements/public/ShipmentCard/ShipmentCard.d.ts +6 -0
  252. package/dist/elements/public/ShipmentCard/ShipmentCard.js +7 -5
  253. package/dist/elements/public/ShipmentCard/ShipmentCard.js.map +1 -1
  254. package/dist/elements/public/ShipmentCard/index.d.ts +1 -0
  255. package/dist/elements/public/ShipmentCard/index.js +1 -0
  256. package/dist/elements/public/ShipmentCard/index.js.map +1 -1
  257. package/dist/elements/public/SwipeActions/SwipeActions.d.ts +16 -1
  258. package/dist/elements/public/SwipeActions/SwipeActions.js +15 -1
  259. package/dist/elements/public/SwipeActions/SwipeActions.js.map +1 -1
  260. package/dist/elements/public/Transaction/Transaction.d.ts +6 -0
  261. package/dist/elements/public/Transaction/Transaction.js +8 -2
  262. package/dist/elements/public/Transaction/Transaction.js.map +1 -1
  263. package/dist/elements/public/Transaction/index.d.ts +2 -4
  264. package/dist/elements/public/Transaction/index.js +2 -4
  265. package/dist/elements/public/Transaction/index.js.map +1 -1
  266. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/InternalTransactionActionsControl.js +8 -12
  267. package/dist/elements/public/Transaction/internal/InternalTransactionActionsControl/InternalTransactionActionsControl.js.map +1 -1
  268. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js +1 -1
  269. package/dist/elements/public/Transaction/internal/InternalTransactionCustomerControl/InternalTransactionCustomerControl.js.map +1 -1
  270. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.d.ts +4 -5
  271. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.js +27 -16
  272. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/InternalTransactionPostActionControl.js.map +1 -1
  273. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.d.ts +1 -0
  274. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.js +1 -0
  275. package/dist/elements/public/Transaction/internal/InternalTransactionPostActionControl/index.js.map +1 -1
  276. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/InternalTransactionSummaryControl.js +12 -23
  277. package/dist/elements/public/Transaction/internal/InternalTransactionSummaryControl/InternalTransactionSummaryControl.js.map +1 -1
  278. package/dist/elements/public/WebhookCard/WebhookCard.d.ts +6 -0
  279. package/dist/elements/public/WebhookCard/WebhookCard.js +8 -2
  280. package/dist/elements/public/WebhookCard/WebhookCard.js.map +1 -1
  281. package/dist/elements/public/WebhookForm/WebhookForm.d.ts +33 -0
  282. package/dist/elements/public/WebhookForm/WebhookForm.js +33 -0
  283. package/dist/elements/public/WebhookForm/WebhookForm.js.map +1 -1
  284. package/dist/elements/public/WebhookForm/index.d.ts +1 -3
  285. package/dist/elements/public/WebhookForm/index.js +1 -3
  286. package/dist/elements/public/WebhookForm/index.js.map +1 -1
  287. package/dist/elements/public/WebhookLogCard/WebhookLogCard.d.ts +6 -0
  288. package/dist/elements/public/WebhookLogCard/WebhookLogCard.js +11 -6
  289. package/dist/elements/public/WebhookLogCard/WebhookLogCard.js.map +1 -1
  290. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.d.ts +6 -0
  291. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.js +6 -0
  292. package/dist/elements/public/WebhookStatusCard/WebhookStatusCard.js.map +1 -1
  293. package/dist/mixins/configurable.js +1 -0
  294. package/dist/mixins/configurable.js.map +1 -1
  295. package/dist/mixins/inferrable.js +1 -0
  296. package/dist/mixins/inferrable.js.map +1 -1
  297. package/dist/mixins/translatable.js +4 -2
  298. package/dist/mixins/translatable.js.map +1 -1
  299. package/package.json +9 -7
  300. package/dist/cdn/shared-25ef9e09.js +0 -1
  301. package/dist/cdn/shared-39b61999.js +0 -1
  302. package/dist/cdn/shared-567c8c48.js +0 -1
  303. package/dist/cdn/shared-58a9174f.js +0 -1
  304. package/dist/cdn/shared-64657919.js +0 -1
  305. package/dist/cdn/shared-67651931.js +0 -1
  306. package/dist/cdn/shared-6a0012d6.js +0 -1
  307. package/dist/cdn/shared-6eb57269.js +0 -15
  308. package/dist/cdn/shared-7a084a40.js +0 -1
  309. package/dist/cdn/shared-85618a7a.js +0 -1
  310. package/dist/cdn/shared-968add7f.js +0 -1
  311. package/dist/cdn/shared-eb0e1f48.js +0 -1
  312. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/InternalTimestampsControl.d.ts +0 -8
  313. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/InternalTimestampsControl.js.map +0 -1
  314. package/dist/elements/internal/InternalForm/internal/InternalTimestampsControl/index.js.map +0 -1
@@ -8,7 +8,7 @@ declare const InternalCard_base: typeof NucleonElement & {
8
8
  * Internal base element for cards.
9
9
  *
10
10
  * @since 1.17.0
11
- * @tag foxy-internal-card
11
+ * @element foxy-internal-card
12
12
  */
13
13
  export declare class InternalCard<TData extends Data> extends InternalCard_base<TData> {
14
14
  /**
@@ -6,7 +6,7 @@ import { html } from 'lit-html';
6
6
  * Internal base element for cards.
7
7
  *
8
8
  * @since 1.17.0
9
- * @tag foxy-internal-card
9
+ * @element foxy-internal-card
10
10
  */
11
11
  export class InternalCard extends ThemeableMixin(NucleonElement) {
12
12
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"InternalCard.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCard/InternalCard.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,cAAc,EAAE,sDAAmD;AAC5E,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhC;;;;;GAKG;AACH,MAAM,OAAO,YAAiC,SAAQ,cAAc,CAAC,cAAc,CAAQ;IACzF;;;OAGG;IACH,UAAU;QACR,OAAO,IAAI,CAAA,EAAE,CAAC;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAA;;oBAEK,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC;;;;;kBAKjB,QAAQ,CAAC;YACf,qCAAqC,EAAE,IAAI;YAC3C,+BAA+B,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;SAChE,CAAC;;YAEA,IAAI,CAAC,UAAU,EAAE;;;;kBAIX,QAAQ,CAAC;YACf,2DAA2D,EAAE,IAAI;YACjE,+BAA+B,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;SAC/D,CAAC;;;qBAGS,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY;oBAC5C,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;;;;;;;KAO3F,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { HALJSONResource as Data } from '../../public/NucleonElement/types';\nimport type { TemplateResult } from 'lit-html';\n\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { NucleonElement } from '../../public/NucleonElement/NucleonElement';\nimport { classMap } from '../../../utils/class-map';\nimport { html } from 'lit-html';\n\n/**\n * Internal base element for cards.\n *\n * @since 1.17.0\n * @tag foxy-internal-card\n */\nexport class InternalCard<TData extends Data> extends ThemeableMixin(NucleonElement)<TData> {\n /**\n * Invoked together with `.render()` to obtain a template for card contents.\n * When extending `InternalCard`, prefer overriding this method to `.render()`.\n */\n renderBody(): TemplateResult {\n return html``;\n }\n\n render(): TemplateResult {\n return html`\n <div\n aria-busy=${this.in('busy')}\n aria-live=\"polite\"\n class=\"relative leading-m text-body text-m font-lumo\"\n >\n <div\n class=${classMap({\n 'transition duration-500 ease-in-out': true,\n 'opacity-0 pointer-events-none': !this.in({ idle: 'snapshot' }),\n })}\n >\n ${this.renderBody()}\n </div>\n\n <div\n class=${classMap({\n 'transition duration-500 ease-in-out absolute inset-0 flex': true,\n 'opacity-0 pointer-events-none': this.in({ idle: 'snapshot' }),\n })}\n >\n <foxy-spinner\n layout=${this.in('busy') ? 'no-label' : 'horizontal'}\n state=${this.in('fail') ? 'error' : this.in({ idle: 'template' }) ? 'empty' : 'busy'}\n class=\"m-auto\"\n infer=\"spinner\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalCard.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCard/InternalCard.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,cAAc,EAAE,sDAAmD;AAC5E,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AACpD,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAEhC;;;;;GAKG;AACH,MAAM,OAAO,YAAiC,SAAQ,cAAc,CAAC,cAAc,CAAQ;IACzF;;;OAGG;IACH,UAAU;QACR,OAAO,IAAI,CAAA,EAAE,CAAC;IAChB,CAAC;IAED,MAAM;QACJ,OAAO,IAAI,CAAA;;oBAEK,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC;;;;;kBAKjB,QAAQ,CAAC;YACf,qCAAqC,EAAE,IAAI;YAC3C,+BAA+B,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;SAChE,CAAC;;YAEA,IAAI,CAAC,UAAU,EAAE;;;;kBAIX,QAAQ,CAAC;YACf,2DAA2D,EAAE,IAAI;YACjE,+BAA+B,EAAE,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;SAC/D,CAAC;;;qBAGS,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,YAAY;oBAC5C,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM;;;;;;;KAO3F,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { HALJSONResource as Data } from '../../public/NucleonElement/types';\nimport type { TemplateResult } from 'lit-html';\n\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { NucleonElement } from '../../public/NucleonElement/NucleonElement';\nimport { classMap } from '../../../utils/class-map';\nimport { html } from 'lit-html';\n\n/**\n * Internal base element for cards.\n *\n * @since 1.17.0\n * @element foxy-internal-card\n */\nexport class InternalCard<TData extends Data> extends ThemeableMixin(NucleonElement)<TData> {\n /**\n * Invoked together with `.render()` to obtain a template for card contents.\n * When extending `InternalCard`, prefer overriding this method to `.render()`.\n */\n renderBody(): TemplateResult {\n return html``;\n }\n\n render(): TemplateResult {\n return html`\n <div\n aria-busy=${this.in('busy')}\n aria-live=\"polite\"\n class=\"relative leading-m text-body text-m font-lumo\"\n >\n <div\n class=${classMap({\n 'transition duration-500 ease-in-out': true,\n 'opacity-0 pointer-events-none': !this.in({ idle: 'snapshot' }),\n })}\n >\n ${this.renderBody()}\n </div>\n\n <div\n class=${classMap({\n 'transition duration-500 ease-in-out absolute inset-0 flex': true,\n 'opacity-0 pointer-events-none': this.in({ idle: 'snapshot' }),\n })}\n >\n <foxy-spinner\n layout=${this.in('busy') ? 'no-label' : 'horizontal'}\n state=${this.in('fail') ? 'error' : this.in({ idle: 'template' }) ? 'empty' : 'busy'}\n class=\"m-auto\"\n infer=\"spinner\"\n >\n </foxy-spinner>\n </div>\n </div>\n `;\n }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import { LitElement, PropertyDeclarations, TemplateResult } from 'lit-element';
1
+ import type { PropertyDeclarations, TemplateResult } from 'lit-element';
2
+ import { LitElement } from 'lit-element';
2
3
  import { NucleonElement } from '../../public/NucleonElement/NucleonElement';
3
4
  declare const InternalControl_base: typeof LitElement & import("lit-element").Constructor<import("../../../mixins/inferrable").InferrableMixinHost> & {
4
5
  inferredProperties: string[];
@@ -7,15 +8,34 @@ declare const InternalControl_base: typeof LitElement & import("lit-element").Co
7
8
  } & import("lit-element").Constructor<import("../../../mixins/translatable").TranslatableMixinHost> & {
8
9
  defaultNS: string;
9
10
  } & import("lit-element").Constructor<import("../../../mixins/configurable").ConfigurableMixinHost>;
11
+ /**
12
+ * An internal base class for any control in a Nucleon form. That control can be as simple as a text field bound
13
+ * to a property or as complex as a query builder, and it infers property values from the
14
+ * parent Nucleon/Configurable/Translatable element, saving the need to manually calculate
15
+ * and bind properties in Lit templates. Each control renders before and after slots in the regular DOM + its
16
+ * own layout in the shadow DOM. When hidden via `hiddencontrols` in the parent,
17
+ * uses `display: none` to hide itself.
18
+ *
19
+ * @element foxy-internal-control
20
+ * @since 1.17.0
21
+ */
10
22
  export declare class InternalControl extends InternalControl_base {
11
23
  static get inferredProperties(): string[];
12
24
  static get properties(): PropertyDeclarations;
25
+ /** NucleonElement instance this control is bound to. */
13
26
  nucleon: NucleonElement<any> | null;
14
- infer: string;
15
27
  inferFromElement(key: string, element: HTMLElement): unknown | undefined;
16
28
  applyInferredProperties(context: Map<string, unknown>): void;
17
29
  updated(changes: Map<keyof this, unknown>): void;
30
+ /**
31
+ * Renders the control itself. In most cases, you will need to implement
32
+ * this method instead of `.render()` in your class to keep the before and after templates/slots.
33
+ */
18
34
  renderControl(): TemplateResult;
35
+ /**
36
+ * Renders the control (if visible) and the before/after templates/slots.
37
+ * You should probably implement `.renderControl()` method instead of this one in your class.
38
+ */
19
39
  render(): TemplateResult;
20
40
  }
21
41
  export {};
@@ -1,15 +1,26 @@
1
- import { html, LitElement } from 'lit-element';
2
- import { render } from 'lit-html';
3
1
  import { ConfigurableMixin } from "../../../mixins/configurable.js";
4
- import { ThemeableMixin } from "../../../mixins/themeable.js";
5
2
  import { TranslatableMixin } from "../../../mixins/translatable.js";
6
- import { NucleonElement } from "../../public/NucleonElement/NucleonElement.js";
3
+ import { html, LitElement } from 'lit-element';
7
4
  import { InferrableMixin } from "../../../mixins/inferrable.js";
5
+ import { ThemeableMixin } from "../../../mixins/themeable.js";
6
+ import { NucleonElement } from "../../public/NucleonElement/NucleonElement.js";
7
+ import { render } from 'lit-html';
8
+ /**
9
+ * An internal base class for any control in a Nucleon form. That control can be as simple as a text field bound
10
+ * to a property or as complex as a query builder, and it infers property values from the
11
+ * parent Nucleon/Configurable/Translatable element, saving the need to manually calculate
12
+ * and bind properties in Lit templates. Each control renders before and after slots in the regular DOM + its
13
+ * own layout in the shadow DOM. When hidden via `hiddencontrols` in the parent,
14
+ * uses `display: none` to hide itself.
15
+ *
16
+ * @element foxy-internal-control
17
+ * @since 1.17.0
18
+ */
8
19
  export class InternalControl extends ConfigurableMixin(TranslatableMixin(ThemeableMixin(InferrableMixin(LitElement)))) {
9
20
  constructor() {
10
21
  super(...arguments);
22
+ /** NucleonElement instance this control is bound to. */
11
23
  this.nucleon = null;
12
- this.infer = '';
13
24
  }
14
25
  static get inferredProperties() {
15
26
  return [...super.inferredProperties, 'nucleon'];
@@ -32,15 +43,25 @@ export class InternalControl extends ConfigurableMixin(TranslatableMixin(Themeab
32
43
  }
33
44
  updated(changes) {
34
45
  super.updated(changes);
35
- this.style.display = this.hidden ? 'none' : '';
36
- render(html `
46
+ if (typeof this.infer === 'string') {
47
+ const lightDomTemplate = html `
37
48
  <slot name="${this.infer}:before" slot="before"></slot>
38
49
  <slot name="${this.infer}:after" slot="after"></slot>
39
- `, this);
50
+ `;
51
+ render(lightDomTemplate, this);
52
+ }
40
53
  }
54
+ /**
55
+ * Renders the control itself. In most cases, you will need to implement
56
+ * this method instead of `.render()` in your class to keep the before and after templates/slots.
57
+ */
41
58
  renderControl() {
42
59
  return html ``;
43
60
  }
61
+ /**
62
+ * Renders the control (if visible) and the before/after templates/slots.
63
+ * You should probably implement `.renderControl()` method instead of this one in your class.
64
+ */
44
65
  render() {
45
66
  if (this.hidden)
46
67
  return html ``;
@@ -1 +1 @@
1
- {"version":3,"file":"InternalControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalControl/InternalControl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAwC,MAAM,aAAa,CAAC;AACrF,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,cAAc,EAAE,sDAAmD;AAC5E,OAAO,EAAE,eAAe,EAAE,sCAAmC;AAE7D,MAAM,OAAO,eAAgB,SAAQ,iBAAiB,CACpD,iBAAiB,CAAC,cAAc,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,CAC/D;IAFD;;QAcE,YAAO,GAA+B,IAAI,CAAC;QAE3C,UAAK,GAAG,EAAE,CAAC;IAsCb,CAAC;IAnDC,MAAM,KAAK,kBAAkB;QAC3B,OAAO,CAAC,GAAG,KAAK,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;IAClD,CAAC;IAED,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;SAC9B,CAAC;IACJ,CAAC;IAMD,gBAAgB,CAAC,GAAW,EAAE,OAAoB;QAChD,IAAI,GAAG,KAAK,SAAS,IAAI,OAAO,YAAY,cAAc;YAAE,OAAO,OAAO,CAAC;QAC3E,OAAO,KAAK,CAAC,gBAAgB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,uBAAuB,CAAC,OAA6B;;QACnD,KAAK,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,SAAI,OAAO,CAAC,GAAG,CAAC,SAAS,CAAqC,mCAAI,IAAI,CAAC;IACrF,CAAC;IAED,OAAO,CAAC,OAAiC;QACvC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAEvB,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC;QAE/C,MAAM,CACJ,IAAI,CAAA;sBACY,IAAI,CAAC,KAAK;sBACV,IAAI,CAAC,KAAK;OACzB,EACD,IAAI,CACL,CAAC;IACJ,CAAC;IAED,aAAa;QACX,OAAO,IAAI,CAAA,EAAE,CAAC;IAChB,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAA,EAAE,CAAC;QAE/B,OAAO,IAAI,CAAA;QACP,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,aAAa,EAAE;QACzE,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC;KACnD,CAAC;IACJ,CAAC;CACF","sourcesContent":["import { html, LitElement, PropertyDeclarations, TemplateResult } from 'lit-element';\nimport { render } from 'lit-html';\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { NucleonElement } from '../../public/NucleonElement/NucleonElement';\nimport { InferrableMixin } from '../../../mixins/inferrable';\n\nexport class InternalControl extends ConfigurableMixin(\n TranslatableMixin(ThemeableMixin(InferrableMixin(LitElement)))\n) {\n static get inferredProperties(): string[] {\n return [...super.inferredProperties, 'nucleon'];\n }\n\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n nucleon: { attribute: false },\n };\n }\n\n nucleon: NucleonElement<any> | null = null;\n\n infer = '';\n\n inferFromElement(key: string, element: HTMLElement): unknown | undefined {\n if (key === 'nucleon' && element instanceof NucleonElement) return element;\n return super.inferFromElement(key, element);\n }\n\n applyInferredProperties(context: Map<string, unknown>): void {\n super.applyInferredProperties(context);\n this.nucleon = (context.get('nucleon') as NucleonElement<any> | undefined) ?? null;\n }\n\n updated(changes: Map<keyof this, unknown>): void {\n super.updated(changes);\n\n this.style.display = this.hidden ? 'none' : '';\n\n render(\n html`\n <slot name=\"${this.infer}:before\" slot=\"before\"></slot>\n <slot name=\"${this.infer}:after\" slot=\"after\"></slot>\n `,\n this\n );\n }\n\n renderControl(): TemplateResult {\n return html``;\n }\n\n render(): TemplateResult {\n if (this.hidden) return html``;\n\n return html`\n ${this.renderTemplateOrSlot('before', this.nucleon)} ${this.renderControl()}\n ${this.renderTemplateOrSlot('after', this.nucleon)}\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalControl/InternalControl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,iBAAiB,EAAE,wCAAqC;AACjE,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,sCAAmC;AAC7D,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,cAAc,EAAE,sDAAmD;AAC5E,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC;;;;;;;;;;GAUG;AACH,MAAM,OAAO,eAAgB,SAAQ,iBAAiB,CACpD,iBAAiB,CAAC,cAAc,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC,CAAC,CAC/D;IAFD;;QAcE,wDAAwD;QACxD,YAAO,GAA+B,IAAI,CAAC;IA6C7C,CAAC;IAzDC,MAAM,KAAK,kBAAkB;QAC3B,OAAO,CAAC,GAAG,KAAK,CAAC,kBAAkB,EAAE,SAAS,CAAC,CAAC;IAClD,CAAC;IAED,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,OAAO,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;SAC9B,CAAC;IACJ,CAAC;IAKD,gBAAgB,CAAC,GAAW,EAAE,OAAoB;QAChD,IAAI,GAAG,KAAK,SAAS,IAAI,OAAO,YAAY,cAAc;YAAE,OAAO,OAAO,CAAC;QAC3E,OAAO,KAAK,CAAC,gBAAgB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC;IAC9C,CAAC;IAED,uBAAuB,CAAC,OAA6B;;QACnD,KAAK,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,SAAI,OAAO,CAAC,GAAG,CAAC,SAAS,CAAqC,mCAAI,IAAI,CAAC;IACrF,CAAC;IAED,OAAO,CAAC,OAAiC;QACvC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QAEvB,IAAI,OAAO,IAAI,CAAC,KAAK,KAAK,QAAQ,EAAE;YAClC,MAAM,gBAAgB,GAAG,IAAI,CAAA;sBACb,IAAI,CAAC,KAAK;sBACV,IAAI,CAAC,KAAK;OACzB,CAAC;YAEF,MAAM,CAAC,gBAAgB,EAAE,IAAI,CAAC,CAAC;SAChC;IACH,CAAC;IAED;;;OAGG;IACH,aAAa;QACX,OAAO,IAAI,CAAA,EAAE,CAAC;IAChB,CAAC;IAED;;;OAGG;IACH,MAAM;QACJ,IAAI,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAA,EAAE,CAAC;QAE/B,OAAO,IAAI,CAAA;QACP,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,aAAa,EAAE;QACzE,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC;KACnD,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { PropertyDeclarations, TemplateResult } from 'lit-element';\n\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { html, LitElement } from 'lit-element';\nimport { InferrableMixin } from '../../../mixins/inferrable';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { NucleonElement } from '../../public/NucleonElement/NucleonElement';\nimport { render } from 'lit-html';\n\n/**\n * An internal base class for any control in a Nucleon form. That control can be as simple as a text field bound\n * to a property or as complex as a query builder, and it infers property values from the\n * parent Nucleon/Configurable/Translatable element, saving the need to manually calculate\n * and bind properties in Lit templates. Each control renders before and after slots in the regular DOM + its\n * own layout in the shadow DOM. When hidden via `hiddencontrols` in the parent,\n * uses `display: none` to hide itself.\n *\n * @element foxy-internal-control\n * @since 1.17.0\n */\nexport class InternalControl extends ConfigurableMixin(\n TranslatableMixin(ThemeableMixin(InferrableMixin(LitElement)))\n) {\n static get inferredProperties(): string[] {\n return [...super.inferredProperties, 'nucleon'];\n }\n\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n nucleon: { attribute: false },\n };\n }\n\n /** NucleonElement instance this control is bound to. */\n nucleon: NucleonElement<any> | null = null;\n\n inferFromElement(key: string, element: HTMLElement): unknown | undefined {\n if (key === 'nucleon' && element instanceof NucleonElement) return element;\n return super.inferFromElement(key, element);\n }\n\n applyInferredProperties(context: Map<string, unknown>): void {\n super.applyInferredProperties(context);\n this.nucleon = (context.get('nucleon') as NucleonElement<any> | undefined) ?? null;\n }\n\n updated(changes: Map<keyof this, unknown>): void {\n super.updated(changes);\n\n if (typeof this.infer === 'string') {\n const lightDomTemplate = html`\n <slot name=\"${this.infer}:before\" slot=\"before\"></slot>\n <slot name=\"${this.infer}:after\" slot=\"after\"></slot>\n `;\n\n render(lightDomTemplate, this);\n }\n }\n\n /**\n * Renders the control itself. In most cases, you will need to implement\n * this method instead of `.render()` in your class to keep the before and after templates/slots.\n */\n renderControl(): TemplateResult {\n return html``;\n }\n\n /**\n * Renders the control (if visible) and the before/after templates/slots.\n * You should probably implement `.renderControl()` method instead of this one in your class.\n */\n render(): TemplateResult {\n if (this.hidden) return html``;\n\n return html`\n ${this.renderTemplateOrSlot('before', this.nucleon)} ${this.renderControl()}\n ${this.renderTemplateOrSlot('after', this.nucleon)}\n `;\n }\n}\n"]}
@@ -1,2 +1,4 @@
1
+ import '../InternalSandbox/index';
2
+ import '../../public/I18n/index';
1
3
  import { InternalControl } from './InternalControl';
2
4
  export { InternalControl };
@@ -1,3 +1,5 @@
1
+ import "../InternalSandbox/index.js";
2
+ import "../../public/I18n/index.js";
1
3
  import { InternalControl } from "./InternalControl.js";
2
4
  customElements.define('foxy-internal-control', InternalControl);
3
5
  export { InternalControl };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalControl/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,6BAA0B;AAEpD,cAAc,CAAC,MAAM,CAAC,uBAAuB,EAAE,eAAe,CAAC,CAAC;AAEhE,OAAO,EAAE,eAAe,EAAE,CAAC","sourcesContent":["import { InternalControl } from './InternalControl';\n\ncustomElements.define('foxy-internal-control', InternalControl);\n\nexport { InternalControl };\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalControl/index.ts"],"names":[],"mappings":"AAAA,qCAAkC;AAClC,oCAAiC;AAEjC,OAAO,EAAE,eAAe,EAAE,6BAA0B;AAEpD,cAAc,CAAC,MAAM,CAAC,uBAAuB,EAAE,eAAe,CAAC,CAAC;AAEhE,OAAO,EAAE,eAAe,EAAE,CAAC","sourcesContent":["import '../InternalSandbox/index';\nimport '../../public/I18n/index';\n\nimport { InternalControl } from './InternalControl';\n\ncustomElements.define('foxy-internal-control', InternalControl);\n\nexport { InternalControl };\n"]}
@@ -5,7 +5,7 @@ import { InternalControl } from '../InternalControl/InternalControl';
5
5
  * submission on click. The button is disabled if the form is invalid.
6
6
  *
7
7
  * @since 1.17.0
8
- * @tag foxy-internal-create-control
8
+ * @element foxy-internal-create-control
9
9
  */
10
10
  export declare class InternalCreateControl extends InternalControl {
11
11
  static get properties(): PropertyDeclarations;
@@ -5,7 +5,7 @@ import { html } from 'lit-element';
5
5
  * submission on click. The button is disabled if the form is invalid.
6
6
  *
7
7
  * @since 1.17.0
8
- * @tag foxy-internal-create-control
8
+ * @element foxy-internal-create-control
9
9
  */
10
10
  export class InternalCreateControl extends InternalControl {
11
11
  constructor() {
@@ -1 +1 @@
1
- {"version":3,"file":"InternalCreateControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCreateControl/InternalCreateControl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,8CAA2C;AACrE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC;;;;;;GAMG;AACH,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAA1D;;QAQE,oEAAoE;QACpE,UAAK,GAAG,iBAAiB,CAAC;IA0C5B,CAAC;IAlDC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACxB,CAAC;IACJ,CAAC;IAKD,aAAa;QACX,OAAO,IAAI,CAAA;;;gBAGC,IAAI,CAAC,KAAK;oBACN,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW;iBACpC,GAAG,EAAE,wBAAC,IAAI,CAAC,OAAO,0CAAE,MAAM,KAAE;;;;KAIxC,CAAC;IACJ,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,mBAAmB;QAC7B,OAAO,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,wBAAwB,CAAC;IACxE,CAAC;IAED,IAAY,mBAAmB;QAC7B,OAAO,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,wBAAwB,CAAC;IACxE,CAAC;IAED,IAAY,WAAW;QACrB,OAAO,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC;IAC9D,CAAC;CACF","sourcesContent":["import type { TemplateResult, PropertyDeclarations } from 'lit-element';\n\nimport { InternalControl } from '../InternalControl/InternalControl';\nimport { html } from 'lit-element';\n\n/**\n * Internal control displaying a \"Create\" button that triggers Nucleon form\n * submission on click. The button is disabled if the form is invalid.\n *\n * @since 1.17.0\n * @tag foxy-internal-create-control\n */\nexport class InternalCreateControl extends InternalControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n theme: { type: String },\n };\n }\n\n /** Same as the \"theme\" attribute of the `vaadin-button` element. */\n theme = 'primary success';\n\n renderControl(): TemplateResult {\n return html`\n <vaadin-button\n class=\"w-full\"\n theme=${this.theme}\n ?disabled=${this.disabled || this.__isInvalid}\n @click=${() => this.nucleon?.submit()}\n >\n <foxy-i18n infer=\"\" key=\"create\"></foxy-i18n>\n </vaadin-button>\n `;\n }\n\n private get __isCleanTemplateInvalid() {\n return !!this.nucleon?.in({ idle: { template: { clean: 'invalid' } } });\n }\n\n private get __isDirtyTemplateInvalid() {\n return !!this.nucleon?.in({ idle: { template: { dirty: 'invalid' } } });\n }\n\n private get __isCleanSnapshotInvalid() {\n return !!this.nucleon?.in({ idle: { snapshot: { clean: 'invalid' } } });\n }\n\n private get __isDirtySnapshotInvalid() {\n return !!this.nucleon?.in({ idle: { snapshot: { dirty: 'invalid' } } });\n }\n\n private get __isTemplateInvalid() {\n return this.__isCleanTemplateInvalid || this.__isDirtyTemplateInvalid;\n }\n\n private get __isSnapshotInvalid() {\n return this.__isCleanSnapshotInvalid || this.__isDirtySnapshotInvalid;\n }\n\n private get __isInvalid() {\n return this.__isSnapshotInvalid || this.__isTemplateInvalid;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalCreateControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCreateControl/InternalCreateControl.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,8CAA2C;AACrE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC;;;;;;GAMG;AACH,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAA1D;;QAQE,oEAAoE;QACpE,UAAK,GAAG,iBAAiB,CAAC;IA0C5B,CAAC;IAlDC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACxB,CAAC;IACJ,CAAC;IAKD,aAAa;QACX,OAAO,IAAI,CAAA;;;gBAGC,IAAI,CAAC,KAAK;oBACN,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,WAAW;iBACpC,GAAG,EAAE,wBAAC,IAAI,CAAC,OAAO,0CAAE,MAAM,KAAE;;;;KAIxC,CAAC;IACJ,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,wBAAwB;;QAClC,OAAO,CAAC,QAAC,IAAI,CAAC,OAAO,0CAAE,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAE,EAAE,EAAC,CAAC;IAC1E,CAAC;IAED,IAAY,mBAAmB;QAC7B,OAAO,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,wBAAwB,CAAC;IACxE,CAAC;IAED,IAAY,mBAAmB;QAC7B,OAAO,IAAI,CAAC,wBAAwB,IAAI,IAAI,CAAC,wBAAwB,CAAC;IACxE,CAAC;IAED,IAAY,WAAW;QACrB,OAAO,IAAI,CAAC,mBAAmB,IAAI,IAAI,CAAC,mBAAmB,CAAC;IAC9D,CAAC;CACF","sourcesContent":["import type { TemplateResult, PropertyDeclarations } from 'lit-element';\n\nimport { InternalControl } from '../InternalControl/InternalControl';\nimport { html } from 'lit-element';\n\n/**\n * Internal control displaying a \"Create\" button that triggers Nucleon form\n * submission on click. The button is disabled if the form is invalid.\n *\n * @since 1.17.0\n * @element foxy-internal-create-control\n */\nexport class InternalCreateControl extends InternalControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n theme: { type: String },\n };\n }\n\n /** Same as the \"theme\" attribute of the `vaadin-button` element. */\n theme = 'primary success';\n\n renderControl(): TemplateResult {\n return html`\n <vaadin-button\n class=\"w-full\"\n theme=${this.theme}\n ?disabled=${this.disabled || this.__isInvalid}\n @click=${() => this.nucleon?.submit()}\n >\n <foxy-i18n infer=\"\" key=\"create\"></foxy-i18n>\n </vaadin-button>\n `;\n }\n\n private get __isCleanTemplateInvalid() {\n return !!this.nucleon?.in({ idle: { template: { clean: 'invalid' } } });\n }\n\n private get __isDirtyTemplateInvalid() {\n return !!this.nucleon?.in({ idle: { template: { dirty: 'invalid' } } });\n }\n\n private get __isCleanSnapshotInvalid() {\n return !!this.nucleon?.in({ idle: { snapshot: { clean: 'invalid' } } });\n }\n\n private get __isDirtySnapshotInvalid() {\n return !!this.nucleon?.in({ idle: { snapshot: { dirty: 'invalid' } } });\n }\n\n private get __isTemplateInvalid() {\n return this.__isCleanTemplateInvalid || this.__isDirtyTemplateInvalid;\n }\n\n private get __isSnapshotInvalid() {\n return this.__isCleanSnapshotInvalid || this.__isDirtySnapshotInvalid;\n }\n\n private get __isInvalid() {\n return this.__isSnapshotInvalid || this.__isTemplateInvalid;\n }\n}\n"]}
@@ -1,4 +1,5 @@
1
- import '../../public/I18n/index';
2
1
  import '@vaadin/vaadin-button';
2
+ import '../../public/I18n/index';
3
+ import '../InternalControl/index';
3
4
  import { InternalCreateControl } from './InternalCreateControl';
4
5
  export { InternalCreateControl };
@@ -1,5 +1,6 @@
1
- import "../../public/I18n/index.js";
2
1
  import '@vaadin/vaadin-button';
2
+ import "../../public/I18n/index.js";
3
+ import "../InternalControl/index.js";
3
4
  import { InternalCreateControl } from "./InternalCreateControl.js";
4
5
  customElements.define('foxy-internal-create-control', InternalCreateControl);
5
6
  export { InternalCreateControl };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCreateControl/index.ts"],"names":[],"mappings":"AAAA,oCAAiC;AACjC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,qBAAqB,EAAE,mCAAgC;AAEhE,cAAc,CAAC,MAAM,CAAC,8BAA8B,EAAE,qBAAqB,CAAC,CAAC;AAE7E,OAAO,EAAE,qBAAqB,EAAE,CAAC","sourcesContent":["import '../../public/I18n/index';\nimport '@vaadin/vaadin-button';\nimport { InternalCreateControl } from './InternalCreateControl';\n\ncustomElements.define('foxy-internal-create-control', InternalCreateControl);\n\nexport { InternalCreateControl };\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalCreateControl/index.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAE/B,oCAAiC;AACjC,qCAAkC;AAElC,OAAO,EAAE,qBAAqB,EAAE,mCAAgC;AAEhE,cAAc,CAAC,MAAM,CAAC,8BAA8B,EAAE,qBAAqB,CAAC,CAAC;AAE7E,OAAO,EAAE,qBAAqB,EAAE,CAAC","sourcesContent":["import '@vaadin/vaadin-button';\n\nimport '../../public/I18n/index';\nimport '../InternalControl/index';\n\nimport { InternalCreateControl } from './InternalCreateControl';\n\ncustomElements.define('foxy-internal-create-control', InternalCreateControl);\n\nexport { InternalCreateControl };\n"]}
@@ -4,7 +4,7 @@ import { InternalEditableControl } from '../InternalEditableControl/InternalEdit
4
4
  * Internal control displaying a basic date picker box.
5
5
  *
6
6
  * @since 1.17.0
7
- * @tag foxy-internal-date-control
7
+ * @element foxy-internal-date-control
8
8
  */
9
9
  export declare class InternalDateControl extends InternalEditableControl {
10
10
  static get properties(): PropertyDeclarations;
@@ -7,7 +7,7 @@ import { html } from 'lit-element';
7
7
  * Internal control displaying a basic date picker box.
8
8
  *
9
9
  * @since 1.17.0
10
- * @tag foxy-internal-date-control
10
+ * @element foxy-internal-date-control
11
11
  */
12
12
  export class InternalDateControl extends InternalEditableControl {
13
13
  constructor() {
@@ -1 +1 @@
1
- {"version":3,"file":"InternalDateControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDateControl/InternalDateControl.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,8DAA2D;AAC7F,OAAO,EAAE,aAAa,EAAE,yCAAsC;AAC9D,OAAO,EAAE,SAAS,EAAE,qCAAkC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC;;;;;GAKG;AACH,MAAM,OAAO,mBAAoB,SAAQ,uBAAuB;IAAhE;;QAQE,kHAAkH;QAClH,WAAM,GAAkB,IAAI,CAAC;IAoC/B,CAAC;IA5CC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACzB,CAAC;IACJ,CAAC;IAKD,aAAa;;QACX,IAAI,KAAa,CAAC;QAElB,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;YAC1B,KAAK,GAAG,aAAa,CAAC,IAAI,IAAI,CAAC,OAAE,IAAI,CAAC,MAAiB,mCAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;SACxE;aAAM;YACL,KAAK,GAAG,IAAI,CAAC,MAAgB,CAAC;SAC/B;QAED,OAAO,IAAI,CAAA;;wBAES,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC;sBAC/B,IAAI,CAAC,WAAW;sBAChB,IAAI,CAAC,UAAU;gBACrB,IAAI,CAAC,KAAK;;oBAEN,IAAI,CAAC,QAAQ;oBACb,IAAI,CAAC,QAAQ;yBACR,IAAI,CAAC,cAAc;iBAC3B,KAAK;mBACH,CAAC,GAAkB,EAAE,EAAE,WAAC,OAAA,GAAG,CAAC,GAAG,KAAK,OAAO,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,GAAE,CAAA,EAAA;kBACtE,CAAC,GAAgB,EAAE,EAAE;;YAC7B,MAAM,KAAK,GAAG,GAAG,CAAC,aAAkC,CAAC;YAErD,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;gBAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,aAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,0CAAE,OAAO,qCAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;aAC3E;iBAAM;gBACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;aAC3B;QACH,CAAC;;;KAGJ,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { TemplateResult, PropertyDeclarations } from 'lit-element';\nimport type { DatePickerElement } from '@vaadin/vaadin-date-picker';\n\nimport { InternalEditableControl } from '../InternalEditableControl/InternalEditableControl';\nimport { serializeDate } from '../../../utils/serialize-date';\nimport { parseDate } from '../../../utils/parse-date';\nimport { ifDefined } from 'lit-html/directives/if-defined';\nimport { html } from 'lit-element';\n\n/**\n * Internal control displaying a basic date picker box.\n *\n * @since 1.17.0\n * @tag foxy-internal-date-control\n */\nexport class InternalDateControl extends InternalEditableControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n format: { type: String },\n };\n }\n\n /** Date format. If `unix`, expects and outputs a UNIX timestamp (number), otherwise defaults to ISO 8601 date. */\n format: 'unix' | null = null;\n\n renderControl(): TemplateResult {\n let value: string;\n\n if (this.format === 'unix') {\n value = serializeDate(new Date(((this._value as number) ?? 0) * 1000));\n } else {\n value = this._value as string;\n }\n\n return html`\n <vaadin-date-picker\n error-message=${ifDefined(this._errorMessage)}\n placeholder=${this.placeholder}\n helper-text=${this.helperText}\n label=${this.label}\n class=\"w-full\"\n ?disabled=${this.disabled}\n ?readonly=${this.readonly}\n .checkValidity=${this._checkValidity}\n .value=${value}\n @keydown=${(evt: KeyboardEvent) => evt.key === 'Enter' && this.nucleon?.submit()}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as DatePickerElement;\n\n if (this.format === 'unix') {\n this._value = Math.floor((parseDate(field.value)?.getTime() ?? 0) / 1000);\n } else {\n this._value = field.value;\n }\n }}\n >\n </vaadin-date-picker>\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalDateControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDateControl/InternalDateControl.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,uBAAuB,EAAE,8DAA2D;AAC7F,OAAO,EAAE,aAAa,EAAE,yCAAsC;AAC9D,OAAO,EAAE,SAAS,EAAE,qCAAkC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,gCAAgC,CAAC;AAC3D,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC;;;;;GAKG;AACH,MAAM,OAAO,mBAAoB,SAAQ,uBAAuB;IAAhE;;QAQE,kHAAkH;QAClH,WAAM,GAAkB,IAAI,CAAC;IAoC/B,CAAC;IA5CC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACzB,CAAC;IACJ,CAAC;IAKD,aAAa;;QACX,IAAI,KAAa,CAAC;QAElB,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;YAC1B,KAAK,GAAG,aAAa,CAAC,IAAI,IAAI,CAAC,OAAE,IAAI,CAAC,MAAiB,mCAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC;SACxE;aAAM;YACL,KAAK,GAAG,IAAI,CAAC,MAAgB,CAAC;SAC/B;QAED,OAAO,IAAI,CAAA;;wBAES,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC;sBAC/B,IAAI,CAAC,WAAW;sBAChB,IAAI,CAAC,UAAU;gBACrB,IAAI,CAAC,KAAK;;oBAEN,IAAI,CAAC,QAAQ;oBACb,IAAI,CAAC,QAAQ;yBACR,IAAI,CAAC,cAAc;iBAC3B,KAAK;mBACH,CAAC,GAAkB,EAAE,EAAE,WAAC,OAAA,GAAG,CAAC,GAAG,KAAK,OAAO,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,GAAE,CAAA,EAAA;kBACtE,CAAC,GAAgB,EAAE,EAAE;;YAC7B,MAAM,KAAK,GAAG,GAAG,CAAC,aAAkC,CAAC;YAErD,IAAI,IAAI,CAAC,MAAM,KAAK,MAAM,EAAE;gBAC1B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,aAAC,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,0CAAE,OAAO,qCAAM,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;aAC3E;iBAAM;gBACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;aAC3B;QACH,CAAC;;;KAGJ,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { TemplateResult, PropertyDeclarations } from 'lit-element';\nimport type { DatePickerElement } from '@vaadin/vaadin-date-picker';\n\nimport { InternalEditableControl } from '../InternalEditableControl/InternalEditableControl';\nimport { serializeDate } from '../../../utils/serialize-date';\nimport { parseDate } from '../../../utils/parse-date';\nimport { ifDefined } from 'lit-html/directives/if-defined';\nimport { html } from 'lit-element';\n\n/**\n * Internal control displaying a basic date picker box.\n *\n * @since 1.17.0\n * @element foxy-internal-date-control\n */\nexport class InternalDateControl extends InternalEditableControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n format: { type: String },\n };\n }\n\n /** Date format. If `unix`, expects and outputs a UNIX timestamp (number), otherwise defaults to ISO 8601 date. */\n format: 'unix' | null = null;\n\n renderControl(): TemplateResult {\n let value: string;\n\n if (this.format === 'unix') {\n value = serializeDate(new Date(((this._value as number) ?? 0) * 1000));\n } else {\n value = this._value as string;\n }\n\n return html`\n <vaadin-date-picker\n error-message=${ifDefined(this._errorMessage)}\n placeholder=${this.placeholder}\n helper-text=${this.helperText}\n label=${this.label}\n class=\"w-full\"\n ?disabled=${this.disabled}\n ?readonly=${this.readonly}\n .checkValidity=${this._checkValidity}\n .value=${value}\n @keydown=${(evt: KeyboardEvent) => evt.key === 'Enter' && this.nucleon?.submit()}\n @change=${(evt: CustomEvent) => {\n const field = evt.currentTarget as DatePickerElement;\n\n if (this.format === 'unix') {\n this._value = Math.floor((parseDate(field.value)?.getTime() ?? 0) / 1000);\n } else {\n this._value = field.value;\n }\n }}\n >\n </vaadin-date-picker>\n `;\n }\n}\n"]}
@@ -1,8 +1,15 @@
1
1
  import type { PropertyDeclarations, TemplateResult } from 'lit-element';
2
2
  import { InternalControl } from '../InternalControl/InternalControl';
3
+ /**
4
+ * Internal control displaying a "Delete" button that triggers resource
5
+ * deletion in Nucleon on click.
6
+ *
7
+ * @since 1.17.0
8
+ * @element foxy-internal-delete-control
9
+ */
3
10
  export declare class InternalDeleteControl extends InternalControl {
4
11
  static get properties(): PropertyDeclarations;
5
- infer: string;
12
+ /** Same as the "theme" attribute of the `vaadin-button` element. */
6
13
  theme: string;
7
14
  renderControl(): TemplateResult;
8
15
  }
@@ -1,9 +1,16 @@
1
1
  import { InternalControl } from "../InternalControl/InternalControl.js";
2
2
  import { html } from 'lit-element';
3
+ /**
4
+ * Internal control displaying a "Delete" button that triggers resource
5
+ * deletion in Nucleon on click.
6
+ *
7
+ * @since 1.17.0
8
+ * @element foxy-internal-delete-control
9
+ */
3
10
  export class InternalDeleteControl extends InternalControl {
4
11
  constructor() {
5
12
  super(...arguments);
6
- this.infer = 'delete';
13
+ /** Same as the "theme" attribute of the `vaadin-button` element. */
7
14
  this.theme = 'primary error';
8
15
  }
9
16
  static get properties() {
@@ -15,14 +22,12 @@ export class InternalDeleteControl extends InternalControl {
15
22
  renderControl() {
16
23
  return html `
17
24
  <foxy-internal-confirm-dialog
18
- data-testid="confirm"
19
25
  message="delete_prompt"
20
26
  confirm="delete"
21
27
  cancel="cancel"
22
28
  header="delete"
23
29
  theme="primary error"
24
- lang=${this.lang}
25
- ns=${this.ns}
30
+ infer=""
26
31
  id="confirm"
27
32
  @hide=${(evt) => { var _a; return !evt.detail.cancelled && ((_a = this.nucleon) === null || _a === void 0 ? void 0 : _a.delete()); }}
28
33
  >
@@ -38,7 +43,7 @@ export class InternalDeleteControl extends InternalControl {
38
43
  confirm.show(evt.currentTarget);
39
44
  }}
40
45
  >
41
- <foxy-i18n ns=${this.ns} key="delete" lang=${this.lang}></foxy-i18n>
46
+ <foxy-i18n infer="" key="delete"></foxy-i18n>
42
47
  </vaadin-button>
43
48
  `;
44
49
  }
@@ -1 +1 @@
1
- {"version":3,"file":"InternalDeleteControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDeleteControl/InternalDeleteControl.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,eAAe,EAAE,8CAA2C;AACrE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAA1D;;QAQE,UAAK,GAAG,QAAQ,CAAC;QAEjB,UAAK,GAAG,eAAe,CAAC;IAgC1B,CAAC;IAzCC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACxB,CAAC;IACJ,CAAC;IAMD,aAAa;QACX,OAAO,IAAI,CAAA;;;;;;;;eAQA,IAAI,CAAC,IAAI;aACX,IAAI,CAAC,EAAE;;gBAEJ,CAAC,GAAoB,EAAE,EAAE,WAAC,OAAA,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,GAAE,CAAA,EAAA;;;;;;gBAMzE,IAAI,CAAC,KAAK;;oBAEN,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;iBACjC,CAAC,GAAgB,EAAE,EAAE;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAA0B,CAAC;YACnF,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,aAA8B,CAAC,CAAC;QACnD,CAAC;;wBAEe,IAAI,CAAC,EAAE,sBAAsB,IAAI,CAAC,IAAI;;KAEzD,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { InternalConfirmDialog } from '../InternalConfirmDialog/InternalConfirmDialog';\nimport type { DialogHideEvent } from '../../private/Dialog/DialogHideEvent';\nimport type { PropertyDeclarations, TemplateResult } from 'lit-element';\nimport type { ButtonElement } from '@vaadin/vaadin-button';\n\nimport { InternalControl } from '../InternalControl/InternalControl';\nimport { html } from 'lit-element';\n\nexport class InternalDeleteControl extends InternalControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n theme: { type: String },\n };\n }\n\n infer = 'delete';\n\n theme = 'primary error';\n\n renderControl(): TemplateResult {\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=${this.lang}\n ns=${this.ns}\n id=\"confirm\"\n @hide=${(evt: DialogHideEvent) => !evt.detail.cancelled && this.nucleon?.delete()}\n >\n </foxy-internal-confirm-dialog>\n\n <vaadin-button\n data-testid=\"delete\"\n theme=${this.theme}\n class=\"w-full\"\n ?disabled=${this.disabled || this.readonly}\n @click=${(evt: CustomEvent) => {\n const confirm = this.renderRoot.querySelector('#confirm') as InternalConfirmDialog;\n confirm.show(evt.currentTarget as ButtonElement);\n }}\n >\n <foxy-i18n ns=${this.ns} key=\"delete\" lang=${this.lang}></foxy-i18n>\n </vaadin-button>\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalDeleteControl.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDeleteControl/InternalDeleteControl.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,eAAe,EAAE,8CAA2C;AACrE,OAAO,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAEnC;;;;;;GAMG;AACH,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAA1D;;QAQE,oEAAoE;QACpE,UAAK,GAAG,eAAe,CAAC;IA8B1B,CAAC;IAtCC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;SACxB,CAAC;IACJ,CAAC;IAKD,aAAa;QACX,OAAO,IAAI,CAAA;;;;;;;;;gBASC,CAAC,GAAoB,EAAE,EAAE,WAAC,OAAA,CAAC,GAAG,CAAC,MAAM,CAAC,SAAS,WAAI,IAAI,CAAC,OAAO,0CAAE,MAAM,GAAE,CAAA,EAAA;;;;;;gBAMzE,IAAI,CAAC,KAAK;;oBAEN,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;iBACjC,CAAC,GAAgB,EAAE,EAAE;YAC5B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,UAAU,CAA0B,CAAC;YACnF,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,aAA8B,CAAC,CAAC;QACnD,CAAC;;;;KAIJ,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { InternalConfirmDialog } from '../InternalConfirmDialog/InternalConfirmDialog';\nimport type { DialogHideEvent } from '../../private/Dialog/DialogHideEvent';\nimport type { PropertyDeclarations, TemplateResult } from 'lit-element';\nimport type { ButtonElement } from '@vaadin/vaadin-button';\n\nimport { InternalControl } from '../InternalControl/InternalControl';\nimport { html } from 'lit-element';\n\n/**\n * Internal control displaying a \"Delete\" button that triggers resource\n * deletion in Nucleon on click.\n *\n * @since 1.17.0\n * @element foxy-internal-delete-control\n */\nexport class InternalDeleteControl extends InternalControl {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n theme: { type: String },\n };\n }\n\n /** Same as the \"theme\" attribute of the `vaadin-button` element. */\n theme = 'primary error';\n\n renderControl(): TemplateResult {\n return html`\n <foxy-internal-confirm-dialog\n message=\"delete_prompt\"\n confirm=\"delete\"\n cancel=\"cancel\"\n header=\"delete\"\n theme=\"primary error\"\n infer=\"\"\n id=\"confirm\"\n @hide=${(evt: DialogHideEvent) => !evt.detail.cancelled && this.nucleon?.delete()}\n >\n </foxy-internal-confirm-dialog>\n\n <vaadin-button\n data-testid=\"delete\"\n theme=${this.theme}\n class=\"w-full\"\n ?disabled=${this.disabled || this.readonly}\n @click=${(evt: CustomEvent) => {\n const confirm = this.renderRoot.querySelector('#confirm') as InternalConfirmDialog;\n confirm.show(evt.currentTarget as ButtonElement);\n }}\n >\n <foxy-i18n infer=\"\" key=\"delete\"></foxy-i18n>\n </vaadin-button>\n `;\n }\n}\n"]}
@@ -1,5 +1,6 @@
1
- import '../InternalConfirmDialog/index';
2
- import '../../public/I18n/index';
3
1
  import '@vaadin/vaadin-button';
2
+ import '../../public/I18n/index';
3
+ import '../InternalConfirmDialog/index';
4
+ import '../InternalControl/index';
4
5
  import { InternalDeleteControl } from './InternalDeleteControl';
5
6
  export { InternalDeleteControl };
@@ -1,6 +1,7 @@
1
- import "../InternalConfirmDialog/index.js";
2
- import "../../public/I18n/index.js";
3
1
  import '@vaadin/vaadin-button';
2
+ import "../../public/I18n/index.js";
3
+ import "../InternalConfirmDialog/index.js";
4
+ import "../InternalControl/index.js";
4
5
  import { InternalDeleteControl } from "./InternalDeleteControl.js";
5
6
  customElements.define('foxy-internal-delete-control', InternalDeleteControl);
6
7
  export { InternalDeleteControl };
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDeleteControl/index.ts"],"names":[],"mappings":"AAAA,2CAAwC;AACxC,oCAAiC;AACjC,OAAO,uBAAuB,CAAC;AAC/B,OAAO,EAAE,qBAAqB,EAAE,mCAAgC;AAEhE,cAAc,CAAC,MAAM,CAAC,8BAA8B,EAAE,qBAAqB,CAAC,CAAC;AAE7E,OAAO,EAAE,qBAAqB,EAAE,CAAC","sourcesContent":["import '../InternalConfirmDialog/index';\nimport '../../public/I18n/index';\nimport '@vaadin/vaadin-button';\nimport { InternalDeleteControl } from './InternalDeleteControl';\n\ncustomElements.define('foxy-internal-delete-control', InternalDeleteControl);\n\nexport { InternalDeleteControl };\n"]}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDeleteControl/index.ts"],"names":[],"mappings":"AAAA,OAAO,uBAAuB,CAAC;AAE/B,oCAAiC;AACjC,2CAAwC;AACxC,qCAAkC;AAElC,OAAO,EAAE,qBAAqB,EAAE,mCAAgC;AAEhE,cAAc,CAAC,MAAM,CAAC,8BAA8B,EAAE,qBAAqB,CAAC,CAAC;AAE7E,OAAO,EAAE,qBAAqB,EAAE,CAAC","sourcesContent":["import '@vaadin/vaadin-button';\n\nimport '../../public/I18n/index';\nimport '../InternalConfirmDialog/index';\nimport '../InternalControl/index';\n\nimport { InternalDeleteControl } from './InternalDeleteControl';\n\ncustomElements.define('foxy-internal-delete-control', InternalDeleteControl);\n\nexport { InternalDeleteControl };\n"]}
@@ -9,7 +9,7 @@ declare const InternalDetails_base: typeof LitElement & import("lit-element").Co
9
9
  * Internal details/summary control.
10
10
  *
11
11
  * @since 1.17.0
12
- * @tag foxy-internal-details
12
+ * @element foxy-internal-details
13
13
  */
14
14
  export declare class InternalDetails extends InternalDetails_base {
15
15
  static get properties(): PropertyDeclarations;
@@ -6,7 +6,7 @@ import { classMap } from "../../../utils/class-map.js";
6
6
  * Internal details/summary control.
7
7
  *
8
8
  * @since 1.17.0
9
- * @tag foxy-internal-details
9
+ * @element foxy-internal-details
10
10
  */
11
11
  export class InternalDetails extends ThemeableMixin(InferrableMixin(LitElement)) {
12
12
  constructor() {
@@ -1 +1 @@
1
- {"version":3,"file":"InternalDetails.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDetails/InternalDetails.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,sCAAmC;AAC7D,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AAEpD;;;;;GAKG;AACH,MAAM,OAAO,eAAgB,SAAQ,cAAc,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;IAAhF;;QASE,iCAAiC;QACjC,YAAO,GAAkB,IAAI,CAAC;QAE9B,4CAA4C;QAC5C,SAAI,GAAG,KAAK,CAAC;IA6Cf,CAAC;IAzDC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,OAAO,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;SACxB,CAAC;IACJ,CAAC;IAQD,MAAM;;QACJ,OAAO,IAAI,CAAA;;;gBAGC,IAAI,CAAC,IAAI;kBACP,CAAC,GAAU,EAAE,EAAE;YACvB,IAAI,CAAC,IAAI,GAAI,GAAG,CAAC,aAAoC,CAAC,IAAI,CAAC;QAC7D,CAAC;;;kBAGS,QAAQ,CAAC;YACf,wEAAwE,EAAE,IAAI;YAC9E,sDAAsD,EAAE,IAAI;YAC5D,aAAa,EAAE,IAAI;YACnB,aAAa,EAAE,CAAC,IAAI,CAAC,IAAI;SAC1B,CAAC;;;;;;;sBAOU,MAAA,IAAI,CAAC,OAAO,mCAAI,EAAE;;;;;;;;;mCASL,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;;;;;;;;;;KAUzD,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { PropertyDeclarations, TemplateResult } from 'lit-element';\n\nimport { html, LitElement } from 'lit-element';\nimport { InferrableMixin } from '../../../mixins/inferrable';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { classMap } from '../../../utils/class-map';\n\n/**\n * Internal details/summary control.\n *\n * @since 1.17.0\n * @tag foxy-internal-details\n */\nexport class InternalDetails extends ThemeableMixin(InferrableMixin(LitElement)) {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n summary: { type: String },\n open: { type: Boolean },\n };\n }\n\n /** i18n key for summary text. */\n summary: string | null = null;\n\n /** Same as `HTMLDetailsElement['open']`. */\n open = false;\n\n render(): TemplateResult {\n return html`\n <details\n class=\"w-full border border-contrast-10 rounded-t-l rounded-b-l\"\n ?open=${this.open}\n @toggle=${(evt: Event) => {\n this.open = (evt.currentTarget as HTMLDetailsElement).open;\n }}\n >\n <summary\n class=${classMap({\n 'focus-outline-none focus-ring-2 focus-ring-inset focus-ring-primary-50': true,\n 'transition-colors cursor-pointer hover-bg-contrast-5': true,\n 'rounded-t-l': true,\n 'rounded-b-l': !this.open,\n })}\n >\n <div class=\"flex items-center h-m pl-m pr-s\">\n <div class=\"flex items-center flex-1\">\n <foxy-i18n\n class=\"flex items-center text-xs tracking-wide uppercase font-bold text-body\"\n infer=\"\"\n key=${this.summary ?? ''}\n >\n </foxy-i18n>\n\n <slot name=\"actions\"></slot>\n </div>\n\n <iron-icon\n class=\"icon-inline text-xl text-body\"\n icon=\"icons:expand-${this.open ? 'less' : 'more'}\"\n >\n </iron-icon>\n </div>\n </summary>\n\n <div class=\"border-t border-contrast-10\">\n <slot></slot>\n </div>\n </details>\n `;\n }\n}\n"]}
1
+ {"version":3,"file":"InternalDetails.js","sourceRoot":"","sources":["../../../../src/elements/internal/InternalDetails/InternalDetails.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,sCAAmC;AAC7D,OAAO,EAAE,cAAc,EAAE,qCAAkC;AAC3D,OAAO,EAAE,QAAQ,EAAE,oCAAiC;AAEpD;;;;;GAKG;AACH,MAAM,OAAO,eAAgB,SAAQ,cAAc,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;IAAhF;;QASE,iCAAiC;QACjC,YAAO,GAAkB,IAAI,CAAC;QAE9B,4CAA4C;QAC5C,SAAI,GAAG,KAAK,CAAC;IA6Cf,CAAC;IAzDC,MAAM,KAAK,UAAU;QACnB,OAAO;YACL,GAAG,KAAK,CAAC,UAAU;YACnB,OAAO,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE;YACzB,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,EAAE;SACxB,CAAC;IACJ,CAAC;IAQD,MAAM;;QACJ,OAAO,IAAI,CAAA;;;gBAGC,IAAI,CAAC,IAAI;kBACP,CAAC,GAAU,EAAE,EAAE;YACvB,IAAI,CAAC,IAAI,GAAI,GAAG,CAAC,aAAoC,CAAC,IAAI,CAAC;QAC7D,CAAC;;;kBAGS,QAAQ,CAAC;YACf,wEAAwE,EAAE,IAAI;YAC9E,sDAAsD,EAAE,IAAI;YAC5D,aAAa,EAAE,IAAI;YACnB,aAAa,EAAE,CAAC,IAAI,CAAC,IAAI;SAC1B,CAAC;;;;;;;sBAOU,MAAA,IAAI,CAAC,OAAO,mCAAI,EAAE;;;;;;;;;mCASL,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;;;;;;;;;;KAUzD,CAAC;IACJ,CAAC;CACF","sourcesContent":["import type { PropertyDeclarations, TemplateResult } from 'lit-element';\n\nimport { html, LitElement } from 'lit-element';\nimport { InferrableMixin } from '../../../mixins/inferrable';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { classMap } from '../../../utils/class-map';\n\n/**\n * Internal details/summary control.\n *\n * @since 1.17.0\n * @element foxy-internal-details\n */\nexport class InternalDetails extends ThemeableMixin(InferrableMixin(LitElement)) {\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n summary: { type: String },\n open: { type: Boolean },\n };\n }\n\n /** i18n key for summary text. */\n summary: string | null = null;\n\n /** Same as `HTMLDetailsElement['open']`. */\n open = false;\n\n render(): TemplateResult {\n return html`\n <details\n class=\"w-full border border-contrast-10 rounded-t-l rounded-b-l\"\n ?open=${this.open}\n @toggle=${(evt: Event) => {\n this.open = (evt.currentTarget as HTMLDetailsElement).open;\n }}\n >\n <summary\n class=${classMap({\n 'focus-outline-none focus-ring-2 focus-ring-inset focus-ring-primary-50': true,\n 'transition-colors cursor-pointer hover-bg-contrast-5': true,\n 'rounded-t-l': true,\n 'rounded-b-l': !this.open,\n })}\n >\n <div class=\"flex items-center h-m pl-m pr-s\">\n <div class=\"flex items-center flex-1\">\n <foxy-i18n\n class=\"flex items-center text-xs tracking-wide uppercase font-bold text-body\"\n infer=\"\"\n key=${this.summary ?? ''}\n >\n </foxy-i18n>\n\n <slot name=\"actions\"></slot>\n </div>\n\n <iron-icon\n class=\"icon-inline text-xl text-body\"\n icon=\"icons:expand-${this.open ? 'less' : 'more'}\"\n >\n </iron-icon>\n </div>\n </summary>\n\n <div class=\"border-t border-contrast-10\">\n <slot></slot>\n </div>\n </details>\n `;\n }\n}\n"]}
@@ -1,5 +1,14 @@
1
1
  import type { PropertyDeclarations } from 'lit-element';
2
2
  import { InternalControl } from '../InternalControl/InternalControl';
3
+ /**
4
+ * An internal base class for controls that have editing functionality, e.g. a text field.
5
+ * Instances of this class will provide shortcuts for translatable placeholder, label, helper
6
+ * text and more. Unlike a regular control, editable control can not only read from a NucleonElement
7
+ * instance up the DOM tree, but also send changes to it and trigger validation process.
8
+ *
9
+ * @element foxy-internal-editable-control
10
+ * @since 1.17.0
11
+ */
3
12
  export declare class InternalEditableControl extends InternalControl {
4
13
  static get properties(): PropertyDeclarations;
5
14
  private __placeholder;
@@ -7,19 +16,62 @@ export declare class InternalEditableControl extends InternalControl {
7
16
  private __v8nPrefix;
8
17
  private __property;
9
18
  private __label;
19
+ /**
20
+ * Translated placeholder text for this control. You can set your own placeholder text
21
+ * if the default key in the inferred namespace doesn't work for you. Use `.resetPlaceholder()`
22
+ * to restore the default translation.
23
+ */
10
24
  get placeholder(): string;
11
25
  set placeholder(newValue: string);
26
+ /**
27
+ * Translated helper text for this control. You can set your own helper text
28
+ * if the default key in the inferred namespace doesn't work for you. Use `.resetHelperText()`
29
+ * to restore the default translation.
30
+ */
12
31
  get helperText(): string;
13
32
  set helperText(newValue: string);
33
+ /**
34
+ * A prefix for all v8n errors related to this control. You can set your own v8n prefix
35
+ * if the default one doesn't work for you. Use `.resetV8nPrefix()`
36
+ * to restore the default v8n prefix.
37
+ */
14
38
  get v8nPrefix(): string;
15
39
  set v8nPrefix(newValue: string);
40
+ /**
41
+ * Name of the property to bind to inferred from the control name by converting it to snake_case.
42
+ * You can set your own property name if the default inference method produces an incorrect result.
43
+ * Use `.resetProperty()` to restore the default property name.
44
+ */
16
45
  get property(): string;
17
46
  set property(newValue: string);
47
+ /**
48
+ * Translated label for this control. You can set your own label if the default key in the inferred
49
+ * namespace doesn't work for you. Use `.resetLabel()` to restore the default translation.
50
+ */
18
51
  get label(): string;
19
52
  set label(newValue: string);
53
+ /** Restores the default placeholder translation. */
54
+ resetPlaceholder(): void;
55
+ /** Restores the default helper text translation. */
56
+ resetHelperText(): void;
57
+ /** Restores the default v8n prefix for errors. */
58
+ resetV8nPrefix(): void;
59
+ /** Restores the default property name. */
60
+ resetProperty(): void;
61
+ /** Restores the default label translation. */
62
+ resetLabel(): void;
63
+ /**
64
+ * A shortcut to get the inferred value from the NucleonElement instance
65
+ * up the DOM tree. If no such value or instance exists, returns `undefined`.
66
+ * Assigning a value to this property will dispatch a cancelable `change` event
67
+ * with the new value in the detail and write changes to the NucleonElement instance if permitted.
68
+ */
20
69
  protected get _value(): unknown | undefined;
21
70
  protected set _value(newValue: unknown | undefined);
71
+ /** A shortcut returning the first v8n error associated with this control. */
22
72
  protected get _error(): string | undefined;
73
+ /** A shortcut returning the localized text of the first v8n error associated with this control. */
23
74
  protected get _errorMessage(): string | undefined;
75
+ /** A helper returning a `.checkValidity()` function for use with Vaadin elements. */
24
76
  protected get _checkValidity(): () => boolean;
25
77
  }