@foxy.io/elements 1.43.0-beta.2 → 1.43.0-beta.4

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 (372) hide show
  1. package/dist/cdn/foxy-access-recovery-form.js +1 -1
  2. package/dist/cdn/foxy-address-card.js +5 -5
  3. package/dist/cdn/foxy-address-form.js +1 -1
  4. package/dist/cdn/foxy-admin-subscription-card.js +1 -1
  5. package/dist/cdn/foxy-admin-subscription-form.js +1 -1
  6. package/dist/cdn/foxy-api-browser.js +1 -1
  7. package/dist/cdn/foxy-applied-coupon-code-card.js +1 -1
  8. package/dist/cdn/foxy-applied-coupon-code-form.js +1 -1
  9. package/dist/cdn/foxy-applied-tax-card.js +1 -1
  10. package/dist/cdn/foxy-attribute-card.js +1 -1
  11. package/dist/cdn/foxy-attribute-form.js +1 -1
  12. package/dist/cdn/foxy-billing-address-card.js +1 -1
  13. package/dist/cdn/foxy-cancellation-form.js +1 -1
  14. package/dist/cdn/foxy-cart-card.js +1 -1
  15. package/dist/cdn/foxy-cart-form.js +2 -2
  16. package/dist/cdn/foxy-client-card.js +1 -1
  17. package/dist/cdn/foxy-client-form.js +1 -1
  18. package/dist/cdn/foxy-collection-page.js +1 -1
  19. package/dist/cdn/foxy-collection-pages.js +1 -1
  20. package/dist/cdn/foxy-copy-to-clipboard.js +1 -1
  21. package/dist/cdn/foxy-coupon-card.js +1 -1
  22. package/dist/cdn/foxy-coupon-code-card.js +1 -1
  23. package/dist/cdn/foxy-coupon-code-form.js +1 -1
  24. package/dist/cdn/foxy-coupon-codes-form.js +1 -1
  25. package/dist/cdn/foxy-coupon-detail-card.js +1 -1
  26. package/dist/cdn/foxy-coupon-form.js +1 -1
  27. package/dist/cdn/foxy-custom-field-card.js +1 -1
  28. package/dist/cdn/foxy-custom-field-form.js +1 -1
  29. package/dist/cdn/foxy-customer-api.js +1 -1
  30. package/dist/cdn/foxy-customer-card.js +1 -1
  31. package/dist/cdn/foxy-customer-form.js +1 -1
  32. package/dist/cdn/foxy-customer-portal-settings-form.js +1 -1
  33. package/dist/cdn/foxy-customer-portal-settings.js +1 -1
  34. package/dist/cdn/foxy-customer-portal.js +4 -4
  35. package/dist/cdn/foxy-customer.js +5 -5
  36. package/dist/cdn/foxy-customers-table.js +1 -1
  37. package/dist/cdn/foxy-discount-builder.js +1 -1
  38. package/dist/cdn/foxy-discount-card.js +1 -1
  39. package/dist/cdn/foxy-discount-detail-card.js +1 -1
  40. package/dist/cdn/foxy-donation.js +1 -1
  41. package/dist/cdn/foxy-downloadable-card.js +1 -1
  42. package/dist/cdn/foxy-downloadable-form.js +2 -2
  43. package/dist/cdn/foxy-email-template-card.js +1 -1
  44. package/dist/cdn/foxy-email-template-form.js +1 -1
  45. package/dist/cdn/foxy-error-entry-card.js +1 -1
  46. package/dist/cdn/foxy-experimental-add-to-cart-builder.js +1 -1
  47. package/dist/cdn/foxy-filter-attribute-card.js +1 -1
  48. package/dist/cdn/foxy-filter-attribute-form.js +1 -1
  49. package/dist/cdn/foxy-form-dialog.js +1 -1
  50. package/dist/cdn/foxy-generate-codes-form.js +1 -1
  51. package/dist/cdn/foxy-gift-card-card.js +1 -1
  52. package/dist/cdn/foxy-gift-card-code-card.js +1 -1
  53. package/dist/cdn/foxy-gift-card-code-form.js +1 -1
  54. package/dist/cdn/foxy-gift-card-code-log-card.js +1 -1
  55. package/dist/cdn/foxy-gift-card-codes-form.js +1 -1
  56. package/dist/cdn/foxy-gift-card-form.js +1 -1
  57. package/dist/cdn/foxy-i18n-editor.js +3 -3
  58. package/dist/cdn/foxy-i18n.js +1 -1
  59. package/dist/cdn/foxy-integration-card.js +1 -1
  60. package/dist/cdn/foxy-integration-form.js +1 -1
  61. package/dist/cdn/foxy-item-card.js +1 -1
  62. package/dist/cdn/foxy-item-category-card.js +1 -1
  63. package/dist/cdn/foxy-item-category-form.js +1 -1
  64. package/dist/cdn/foxy-item-form.js +1 -1
  65. package/dist/cdn/foxy-item-option-card.js +1 -1
  66. package/dist/cdn/foxy-item-option-form.js +1 -1
  67. package/dist/cdn/foxy-items-form.js +1 -1
  68. package/dist/cdn/foxy-native-integration-card.js +1 -1
  69. package/dist/cdn/foxy-native-integration-form.js +1 -1
  70. package/dist/cdn/foxy-nucleon-element.js +1 -1
  71. package/dist/cdn/foxy-pagination.js +1 -1
  72. package/dist/cdn/foxy-passkey-card.js +1 -1
  73. package/dist/cdn/foxy-passkey-form.js +1 -1
  74. package/dist/cdn/foxy-payment-card-embed.js +1 -1
  75. package/dist/cdn/foxy-payment-card.js +1 -1
  76. package/dist/cdn/foxy-payment-method-card.js +1 -1
  77. package/dist/cdn/foxy-payments-api-fraud-protection-card.js +1 -1
  78. package/dist/cdn/foxy-payments-api-fraud-protection-form.js +1 -1
  79. package/dist/cdn/foxy-payments-api-payment-method-card.js +1 -1
  80. package/dist/cdn/foxy-payments-api-payment-method-form.js +1 -1
  81. package/dist/cdn/foxy-payments-api-payment-preset-card.js +1 -1
  82. package/dist/cdn/foxy-payments-api-payment-preset-form.js +1 -1
  83. package/dist/cdn/foxy-payments-api.js +1 -1
  84. package/dist/cdn/foxy-query-builder.js +1 -1
  85. package/dist/cdn/foxy-report-form.js +2 -2
  86. package/dist/cdn/foxy-reports-table.js +6 -6
  87. package/dist/cdn/foxy-shipment-card.js +1 -1
  88. package/dist/cdn/foxy-shipping-container-card.js +1 -1
  89. package/dist/cdn/foxy-shipping-drop-type-card.js +1 -1
  90. package/dist/cdn/foxy-shipping-method-card.js +1 -1
  91. package/dist/cdn/foxy-shipping-service-card.js +1 -1
  92. package/dist/cdn/foxy-sign-in-form.js +1 -1
  93. package/dist/cdn/foxy-spinner.js +1 -1
  94. package/dist/cdn/foxy-store-card.js +1 -1
  95. package/dist/cdn/foxy-store-form.js +1 -1
  96. package/dist/cdn/foxy-store-shipping-method-form.js +1 -1
  97. package/dist/cdn/foxy-subscription-card.js +1 -1
  98. package/dist/cdn/foxy-subscription-form.js +1 -1
  99. package/dist/cdn/foxy-subscription-settings-form.js +1 -1
  100. package/dist/cdn/foxy-subscriptions-table.js +1 -1
  101. package/dist/cdn/foxy-table.js +1 -1
  102. package/dist/cdn/foxy-tax-card.js +1 -1
  103. package/dist/cdn/foxy-tax-form.js +1 -1
  104. package/dist/cdn/foxy-template-config-form.js +1 -1
  105. package/dist/cdn/foxy-template-form.js +1 -1
  106. package/dist/cdn/foxy-template-set-card.js +1 -1
  107. package/dist/cdn/foxy-template-set-form.js +1 -1
  108. package/dist/cdn/foxy-transaction-card.js +1 -1
  109. package/dist/cdn/foxy-transaction.js +1 -1
  110. package/dist/cdn/foxy-transactions-table.js +7 -7
  111. package/dist/cdn/foxy-update-payment-method-form.js +1 -1
  112. package/dist/cdn/foxy-user-card.js +1 -1
  113. package/dist/cdn/foxy-user-form.js +1 -1
  114. package/dist/cdn/foxy-user-invitation-card.js +1 -1
  115. package/dist/cdn/foxy-user-invitation-form.js +1 -1
  116. package/dist/cdn/foxy-users-table.js +1 -1
  117. package/dist/cdn/foxy-webhook-card.js +1 -1
  118. package/dist/cdn/foxy-webhook-form.js +1 -1
  119. package/dist/cdn/foxy-webhook-log-card.js +1 -1
  120. package/dist/cdn/foxy-webhook-status-card.js +1 -1
  121. package/dist/cdn/{shared-ffd5932d.js → shared-070211c0.js} +1 -1
  122. package/dist/cdn/{shared-0224f0b8.js → shared-0e605594.js} +1 -1
  123. package/dist/cdn/{shared-2aa23b5f.js → shared-0ea750af.js} +1 -1
  124. package/dist/cdn/{shared-6033e09d.js → shared-0fa21237.js} +1 -1
  125. package/dist/cdn/{shared-8f009bbb.js → shared-0fb90a71.js} +1 -1
  126. package/dist/cdn/{shared-eb963ba3.js → shared-12973e93.js} +1 -1
  127. package/dist/cdn/{shared-6962f117.js → shared-140c6b70.js} +1 -1
  128. package/dist/cdn/{shared-bb6d7b97.js → shared-160072f2.js} +1 -1
  129. package/dist/cdn/shared-1b4a3e56.js +1 -0
  130. package/dist/cdn/shared-1da47f50.js +1 -0
  131. package/dist/cdn/{shared-9342ca50.js → shared-1f95aa71.js} +1 -1
  132. package/dist/cdn/shared-2061be9a.js +1 -0
  133. package/dist/cdn/{shared-9b9d5ff1.js → shared-28253ef3.js} +1 -1
  134. package/dist/cdn/{shared-cae7a43b.js → shared-2b328555.js} +1 -1
  135. package/dist/cdn/{shared-4dd24dda.js → shared-2c7e0ed1.js} +1 -1
  136. package/dist/cdn/shared-2d3bdc6b.js +1 -0
  137. package/dist/cdn/{shared-70e6f32c.js → shared-34a7df04.js} +1 -1
  138. package/dist/cdn/{shared-74d599dc.js → shared-364b98a1.js} +1 -1
  139. package/dist/cdn/{shared-5e4a03d1.js → shared-37869bac.js} +1 -1
  140. package/dist/cdn/{shared-99a8889a.js → shared-3b4148ad.js} +1 -1
  141. package/dist/cdn/{shared-5f8c01f8.js → shared-3c64ecdd.js} +1 -1
  142. package/dist/cdn/{shared-6b3fed56.js → shared-3eb6e232.js} +1 -1
  143. package/dist/cdn/{shared-9c010e0a.js → shared-3f4549ba.js} +1 -1
  144. package/dist/cdn/{shared-66201dc5.js → shared-4388f7ea.js} +1 -1
  145. package/dist/cdn/{shared-4b393539.js → shared-46a20973.js} +1 -1
  146. package/dist/cdn/{shared-bedc5e82.js → shared-48129732.js} +1 -1
  147. package/dist/cdn/{shared-2828fcbf.js → shared-50a355d6.js} +1 -1
  148. package/dist/cdn/{shared-4cafa2e7.js → shared-5492f8eb.js} +1 -1
  149. package/dist/cdn/shared-5905fca4.js +1 -0
  150. package/dist/cdn/{shared-8a0bd046.js → shared-59c064c2.js} +1 -1
  151. package/dist/cdn/{shared-2f8e53c0.js → shared-5a6e4a7b.js} +1 -1
  152. package/dist/cdn/{shared-567ba8ae.js → shared-5af5ab06.js} +1 -1
  153. package/dist/cdn/{shared-ad60e8d1.js → shared-6313b188.js} +2 -2
  154. package/dist/cdn/shared-65b2760f.js +1 -0
  155. package/dist/cdn/{shared-89d4000a.js → shared-69c7ad04.js} +1 -1
  156. package/dist/cdn/{shared-e88763ec.js → shared-742899dc.js} +1 -1
  157. package/dist/cdn/{shared-b1435a0a.js → shared-7d1512e1.js} +1 -1
  158. package/dist/cdn/{shared-673d668a.js → shared-7dc40542.js} +1 -1
  159. package/dist/cdn/{shared-9dc36194.js → shared-7e18a7d9.js} +1 -1
  160. package/dist/cdn/shared-7fec42f2.js +15 -0
  161. package/dist/cdn/{shared-656a46f7.js → shared-8530fbae.js} +2 -2
  162. package/dist/cdn/{shared-c832f3a1.js → shared-88a1cb23.js} +1 -1
  163. package/dist/cdn/{shared-d68c6616.js → shared-8a570d01.js} +1 -1
  164. package/dist/cdn/{shared-94716ec1.js → shared-8a743005.js} +1 -1
  165. package/dist/cdn/{shared-e2d3c014.js → shared-9884fb7d.js} +1 -1
  166. package/dist/cdn/{shared-a4216b50.js → shared-9bfb584b.js} +1 -1
  167. package/dist/cdn/{shared-264e8301.js → shared-a0fbe3ef.js} +5 -5
  168. package/dist/cdn/shared-a16ef278.js +1 -0
  169. package/dist/cdn/{shared-a507d54f.js → shared-a41ccdc7.js} +4 -4
  170. package/dist/cdn/{shared-8ea2bbcc.js → shared-a4871405.js} +1 -1
  171. package/dist/cdn/{shared-aa6dab90.js → shared-a89e8a07.js} +2 -2
  172. package/dist/cdn/{shared-678beccf.js → shared-acee789f.js} +3 -3
  173. package/dist/cdn/{shared-dc4d2996.js → shared-ad8d209a.js} +1 -1
  174. package/dist/cdn/{shared-1cd02e50.js → shared-b15efc37.js} +1 -1
  175. package/dist/cdn/shared-be30b940.js +1 -0
  176. package/dist/cdn/{shared-41208627.js → shared-c16f05d9.js} +1 -1
  177. package/dist/cdn/{shared-5afb584d.js → shared-c782b9fa.js} +1 -1
  178. package/dist/cdn/{shared-c502de27.js → shared-ce0df878.js} +1 -1
  179. package/dist/cdn/{shared-9171c265.js → shared-cf6122d9.js} +1 -1
  180. package/dist/cdn/{shared-dd303282.js → shared-d3aefd9b.js} +1 -1
  181. package/dist/cdn/{shared-e6a1eef8.js → shared-d3f37507.js} +1 -1
  182. package/dist/cdn/{shared-fed829c2.js → shared-d4928805.js} +1 -1
  183. package/dist/cdn/{shared-7594e563.js → shared-d6a0954b.js} +1 -1
  184. package/dist/cdn/{shared-d7d949bc.js → shared-d8b0432a.js} +1 -1
  185. package/dist/cdn/shared-da95bb48.js +1 -0
  186. package/dist/cdn/{shared-274dec57.js → shared-db50afd9.js} +1 -1
  187. package/dist/cdn/shared-dc1fc2e6.js +1 -0
  188. package/dist/cdn/shared-dfe59df6.js +1 -0
  189. package/dist/cdn/{shared-7fd51889.js → shared-e02936f0.js} +1 -1
  190. package/dist/cdn/{shared-a6c75cc0.js → shared-e126cf44.js} +1 -1
  191. package/dist/cdn/shared-e1e4d8f5.js +1 -0
  192. package/dist/cdn/shared-e82550b1.js +40 -0
  193. package/dist/cdn/{shared-44b46fef.js → shared-ebfb86b5.js} +1 -1
  194. package/dist/cdn/{shared-0d0585dc.js → shared-f2be9863.js} +1 -1
  195. package/dist/cdn/shared-f2e8070b.js +1 -0
  196. package/dist/cdn/shared-f3590d20.js +15 -0
  197. package/dist/cdn/{shared-cc4b3b42.js → shared-f7b4a4f6.js} +1 -1
  198. package/dist/cdn/shared-f8e1143e.js +1 -0
  199. package/dist/cdn/{shared-2cb397e4.js → shared-fa482a7d.js} +1 -1
  200. package/dist/cdn/translations/cart-form/en.json +42 -41
  201. package/dist/cdn/translations/coupon-form/en.json +38 -26
  202. package/dist/cdn/translations/customer/en.json +14 -17
  203. package/dist/cdn/translations/filter-attribute-form/en.json +19 -14
  204. package/dist/cdn/translations/gift-card-code-form/en.json +14 -16
  205. package/dist/cdn/translations/gift-card-form/en.json +33 -32
  206. package/dist/cdn/translations/payment-method-card/en.json +14 -17
  207. package/dist/cdn/translations/query-builder/en.json +15 -13
  208. package/dist/cdn/translations/update-payment-method-form/en.json +14 -17
  209. package/dist/elements/internal/InternalAsyncListControl/InternalAsyncListControlFilterOverlay.js +1 -1
  210. package/dist/elements/internal/InternalAsyncListControl/InternalAsyncListControlFilterOverlay.js.map +1 -1
  211. package/dist/elements/internal/InternalEditableListControl/InternalEditableListControl.js +5 -4
  212. package/dist/elements/internal/InternalEditableListControl/InternalEditableListControl.js.map +1 -1
  213. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js +9 -10
  214. package/dist/elements/internal/InternalNumberControl/InternalNumberControl.js.map +1 -1
  215. package/dist/elements/internal/InternalSummaryControl/InternalSummaryControl.js +7 -7
  216. package/dist/elements/internal/InternalSummaryControl/InternalSummaryControl.js.map +1 -1
  217. package/dist/elements/public/CouponForm/CouponForm.js +4 -4
  218. package/dist/elements/public/CouponForm/CouponForm.js.map +1 -1
  219. package/dist/elements/public/Donation/Donation.d.ts +3 -0
  220. package/dist/elements/public/Donation/Donation.js +19 -0
  221. package/dist/elements/public/Donation/Donation.js.map +1 -1
  222. package/dist/elements/public/FilterAttributeForm/FilterAttributeForm.d.ts +2 -2
  223. package/dist/elements/public/FilterAttributeForm/FilterAttributeForm.js +59 -24
  224. package/dist/elements/public/FilterAttributeForm/FilterAttributeForm.js.map +1 -1
  225. package/dist/elements/public/FilterAttributeForm/index.d.ts +2 -2
  226. package/dist/elements/public/FilterAttributeForm/index.js +2 -2
  227. package/dist/elements/public/FilterAttributeForm/index.js.map +1 -1
  228. package/dist/elements/public/GiftCardForm/GiftCardForm.js +5 -5
  229. package/dist/elements/public/GiftCardForm/GiftCardForm.js.map +1 -1
  230. package/dist/elements/public/QueryBuilder/QueryBuilder.d.ts +16 -7
  231. package/dist/elements/public/QueryBuilder/QueryBuilder.js +155 -33
  232. package/dist/elements/public/QueryBuilder/QueryBuilder.js.map +1 -1
  233. package/dist/elements/public/QueryBuilder/components/AdvancedGroup.d.ts +16 -0
  234. package/dist/elements/public/QueryBuilder/components/AdvancedGroup.js +78 -0
  235. package/dist/elements/public/QueryBuilder/components/AdvancedGroup.js.map +1 -0
  236. package/dist/elements/public/QueryBuilder/components/AdvancedInput.d.ts +12 -0
  237. package/dist/elements/public/QueryBuilder/components/AdvancedInput.js +50 -0
  238. package/dist/elements/public/QueryBuilder/components/AdvancedInput.js.map +1 -0
  239. package/dist/elements/public/QueryBuilder/components/AdvancedOperatorToggle.d.ts +14 -0
  240. package/dist/elements/public/QueryBuilder/components/AdvancedOperatorToggle.js +41 -0
  241. package/dist/elements/public/QueryBuilder/components/AdvancedOperatorToggle.js.map +1 -0
  242. package/dist/elements/public/QueryBuilder/components/AdvancedRule.d.ts +18 -0
  243. package/dist/elements/public/QueryBuilder/components/{Rule.js → AdvancedRule.js} +50 -59
  244. package/dist/elements/public/QueryBuilder/components/AdvancedRule.js.map +1 -0
  245. package/dist/elements/public/QueryBuilder/components/SimpleAttributeRule.d.ts +2 -0
  246. package/dist/elements/public/QueryBuilder/components/SimpleAttributeRule.js +78 -0
  247. package/dist/elements/public/QueryBuilder/components/SimpleAttributeRule.js.map +1 -0
  248. package/dist/elements/public/QueryBuilder/components/SimpleBooleanRule.d.ts +2 -0
  249. package/dist/elements/public/QueryBuilder/components/SimpleBooleanRule.js +16 -0
  250. package/dist/elements/public/QueryBuilder/components/SimpleBooleanRule.js.map +1 -0
  251. package/dist/elements/public/QueryBuilder/components/SimpleDateRule.d.ts +2 -0
  252. package/dist/elements/public/QueryBuilder/components/SimpleDateRule.js +111 -0
  253. package/dist/elements/public/QueryBuilder/components/SimpleDateRule.js.map +1 -0
  254. package/dist/elements/public/QueryBuilder/components/SimpleGroup.d.ts +14 -0
  255. package/dist/elements/public/QueryBuilder/components/SimpleGroup.js +111 -0
  256. package/dist/elements/public/QueryBuilder/components/SimpleGroup.js.map +1 -0
  257. package/dist/elements/public/QueryBuilder/components/SimpleInput.d.ts +15 -0
  258. package/dist/elements/public/QueryBuilder/components/SimpleInput.js +50 -0
  259. package/dist/elements/public/QueryBuilder/components/SimpleInput.js.map +1 -0
  260. package/dist/elements/public/QueryBuilder/components/SimpleListRule.d.ts +2 -0
  261. package/dist/elements/public/QueryBuilder/components/SimpleListRule.js +45 -0
  262. package/dist/elements/public/QueryBuilder/components/SimpleListRule.js.map +1 -0
  263. package/dist/elements/public/QueryBuilder/components/SimpleNumberRule.d.ts +2 -0
  264. package/dist/elements/public/QueryBuilder/components/SimpleNumberRule.js +100 -0
  265. package/dist/elements/public/QueryBuilder/components/SimpleNumberRule.js.map +1 -0
  266. package/dist/elements/public/QueryBuilder/components/SimpleSelect.d.ts +24 -0
  267. package/dist/elements/public/QueryBuilder/components/SimpleSelect.js +45 -0
  268. package/dist/elements/public/QueryBuilder/components/SimpleSelect.js.map +1 -0
  269. package/dist/elements/public/QueryBuilder/components/SimpleStringRule.d.ts +2 -0
  270. package/dist/elements/public/QueryBuilder/components/SimpleStringRule.js +46 -0
  271. package/dist/elements/public/QueryBuilder/components/SimpleStringRule.js.map +1 -0
  272. package/dist/elements/public/QueryBuilder/icons/field.d.ts +1 -0
  273. package/dist/elements/public/QueryBuilder/icons/{typeAny.js → field.js} +2 -2
  274. package/dist/elements/public/QueryBuilder/icons/field.js.map +1 -0
  275. package/dist/elements/public/QueryBuilder/icons/index.d.ts +1 -6
  276. package/dist/elements/public/QueryBuilder/icons/index.js +1 -6
  277. package/dist/elements/public/QueryBuilder/icons/index.js.map +1 -1
  278. package/dist/elements/public/QueryBuilder/index.d.ts +2 -0
  279. package/dist/elements/public/QueryBuilder/index.js +2 -0
  280. package/dist/elements/public/QueryBuilder/index.js.map +1 -1
  281. package/dist/elements/public/QueryBuilder/styles.js +23 -0
  282. package/dist/elements/public/QueryBuilder/styles.js.map +1 -1
  283. package/dist/elements/public/QueryBuilder/types.d.ts +24 -6
  284. package/dist/elements/public/QueryBuilder/types.js.map +1 -1
  285. package/dist/elements/public/QueryBuilder/utils/parse.d.ts +2 -2
  286. package/dist/elements/public/QueryBuilder/utils/parse.js +19 -16
  287. package/dist/elements/public/QueryBuilder/utils/parse.js.map +1 -1
  288. package/dist/elements/public/QueryBuilder/utils/stringify.d.ts +2 -2
  289. package/dist/elements/public/QueryBuilder/utils/stringify.js +22 -45
  290. package/dist/elements/public/QueryBuilder/utils/stringify.js.map +1 -1
  291. package/dist/elements/public/QueryBuilder/utils/zoom.d.ts +3 -0
  292. package/dist/elements/public/QueryBuilder/utils/zoom.js +29 -0
  293. package/dist/elements/public/QueryBuilder/utils/zoom.js.map +1 -0
  294. package/dist/mixins/themeable.js +17 -18
  295. package/dist/mixins/themeable.js.map +1 -1
  296. package/package.json +1 -1
  297. package/dist/cdn/shared-0aedd809.js +0 -1
  298. package/dist/cdn/shared-210abb90.js +0 -64
  299. package/dist/cdn/shared-2f5cc0e2.js +0 -1
  300. package/dist/cdn/shared-343d1fd7.js +0 -1
  301. package/dist/cdn/shared-4a38cb3e.js +0 -1
  302. package/dist/cdn/shared-4c764a91.js +0 -1
  303. package/dist/cdn/shared-5592ec6e.js +0 -1
  304. package/dist/cdn/shared-5ef40e86.js +0 -1
  305. package/dist/cdn/shared-79d0699c.js +0 -1
  306. package/dist/cdn/shared-87b93771.js +0 -1
  307. package/dist/cdn/shared-894c69f8.js +0 -1
  308. package/dist/cdn/shared-97e2abfb.js +0 -1
  309. package/dist/cdn/shared-c31c50e2.js +0 -1
  310. package/dist/cdn/shared-cb58dfcd.js +0 -15
  311. package/dist/cdn/shared-d0363ae9.js +0 -1
  312. package/dist/cdn/shared-ef4ad461.js +0 -1
  313. package/dist/cdn/shared-f7bfb29e.js +0 -15
  314. package/dist/cdn/shared-f83207fb.js +0 -1
  315. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/InternalFilterAttributeFormActionControl.d.ts +0 -5
  316. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/InternalFilterAttributeFormActionControl.js +0 -34
  317. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/InternalFilterAttributeFormActionControl.js.map +0 -1
  318. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/index.d.ts +0 -5
  319. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/index.js +0 -7
  320. package/dist/elements/public/FilterAttributeForm/internal/InternalFilterAttributeFormActionControl/index.js.map +0 -1
  321. package/dist/elements/public/QueryBuilder/components/BooleanValue.d.ts +0 -12
  322. package/dist/elements/public/QueryBuilder/components/BooleanValue.js +0 -21
  323. package/dist/elements/public/QueryBuilder/components/BooleanValue.js.map +0 -1
  324. package/dist/elements/public/QueryBuilder/components/Group.d.ts +0 -15
  325. package/dist/elements/public/QueryBuilder/components/Group.js +0 -95
  326. package/dist/elements/public/QueryBuilder/components/Group.js.map +0 -1
  327. package/dist/elements/public/QueryBuilder/components/Input.d.ts +0 -19
  328. package/dist/elements/public/QueryBuilder/components/Input.js +0 -109
  329. package/dist/elements/public/QueryBuilder/components/Input.js.map +0 -1
  330. package/dist/elements/public/QueryBuilder/components/IsDefinedValue.d.ts +0 -11
  331. package/dist/elements/public/QueryBuilder/components/IsDefinedValue.js +0 -16
  332. package/dist/elements/public/QueryBuilder/components/IsDefinedValue.js.map +0 -1
  333. package/dist/elements/public/QueryBuilder/components/ListValue.d.ts +0 -12
  334. package/dist/elements/public/QueryBuilder/components/ListValue.js +0 -48
  335. package/dist/elements/public/QueryBuilder/components/ListValue.js.map +0 -1
  336. package/dist/elements/public/QueryBuilder/components/Name.d.ts +0 -11
  337. package/dist/elements/public/QueryBuilder/components/Name.js +0 -14
  338. package/dist/elements/public/QueryBuilder/components/Name.js.map +0 -1
  339. package/dist/elements/public/QueryBuilder/components/OperatorToggle.d.ts +0 -13
  340. package/dist/elements/public/QueryBuilder/components/OperatorToggle.js +0 -63
  341. package/dist/elements/public/QueryBuilder/components/OperatorToggle.js.map +0 -1
  342. package/dist/elements/public/QueryBuilder/components/Path.d.ts +0 -13
  343. package/dist/elements/public/QueryBuilder/components/Path.js +0 -16
  344. package/dist/elements/public/QueryBuilder/components/Path.js.map +0 -1
  345. package/dist/elements/public/QueryBuilder/components/RangeValue.d.ts +0 -12
  346. package/dist/elements/public/QueryBuilder/components/RangeValue.js +0 -49
  347. package/dist/elements/public/QueryBuilder/components/RangeValue.js.map +0 -1
  348. package/dist/elements/public/QueryBuilder/components/Rule.d.ts +0 -18
  349. package/dist/elements/public/QueryBuilder/components/Rule.js.map +0 -1
  350. package/dist/elements/public/QueryBuilder/components/Select.d.ts +0 -16
  351. package/dist/elements/public/QueryBuilder/components/Select.js +0 -86
  352. package/dist/elements/public/QueryBuilder/components/Select.js.map +0 -1
  353. package/dist/elements/public/QueryBuilder/components/SingleValue.d.ts +0 -12
  354. package/dist/elements/public/QueryBuilder/components/SingleValue.js +0 -21
  355. package/dist/elements/public/QueryBuilder/components/SingleValue.js.map +0 -1
  356. package/dist/elements/public/QueryBuilder/icons/typeAny.d.ts +0 -1
  357. package/dist/elements/public/QueryBuilder/icons/typeAny.js.map +0 -1
  358. package/dist/elements/public/QueryBuilder/icons/typeAttribute.d.ts +0 -1
  359. package/dist/elements/public/QueryBuilder/icons/typeAttribute.js +0 -8
  360. package/dist/elements/public/QueryBuilder/icons/typeAttribute.js.map +0 -1
  361. package/dist/elements/public/QueryBuilder/icons/typeBoolean.d.ts +0 -1
  362. package/dist/elements/public/QueryBuilder/icons/typeBoolean.js +0 -10
  363. package/dist/elements/public/QueryBuilder/icons/typeBoolean.js.map +0 -1
  364. package/dist/elements/public/QueryBuilder/icons/typeDate.d.ts +0 -1
  365. package/dist/elements/public/QueryBuilder/icons/typeDate.js +0 -7
  366. package/dist/elements/public/QueryBuilder/icons/typeDate.js.map +0 -1
  367. package/dist/elements/public/QueryBuilder/icons/typeNumber.d.ts +0 -1
  368. package/dist/elements/public/QueryBuilder/icons/typeNumber.js +0 -7
  369. package/dist/elements/public/QueryBuilder/icons/typeNumber.js.map +0 -1
  370. package/dist/elements/public/QueryBuilder/icons/typeString.d.ts +0 -1
  371. package/dist/elements/public/QueryBuilder/icons/typeString.js +0 -7
  372. package/dist/elements/public/QueryBuilder/icons/typeString.js.map +0 -1
@@ -1,14 +1,18 @@
1
- import { LitElement } from 'lit-element';
2
- import { Operator, Type } from "./types.js";
3
- import { Group } from "./components/Group.js";
1
+ import { TranslatableMixin } from "../../../mixins/translatable.js";
2
+ import { ConfigurableMixin } from "../../../mixins/configurable.js";
3
+ import { html, LitElement } from 'lit-element';
4
+ import { InferrableMixin } from "../../../mixins/inferrable.js";
4
5
  import { ResponsiveMixin } from "../../../mixins/responsive.js";
5
6
  import { ThemeableMixin } from "../../../mixins/themeable.js";
6
- import { TranslatableMixin } from "../../../mixins/translatable.js";
7
- import { parse } from "./utils/parse.js";
7
+ import { Operator, Type } from "./types.js";
8
+ import { AdvancedGroup } from "./components/AdvancedGroup.js";
9
+ import { SimpleGroup } from "./components/SimpleGroup.js";
8
10
  import { stringify } from "./utils/stringify.js";
11
+ import { ifDefined } from 'lit-html/directives/if-defined';
12
+ import { classMap } from "../../../utils/class-map.js";
9
13
  import { styles } from "./styles.js";
10
- import { InferrableMixin } from "../../../mixins/inferrable.js";
11
- import { ConfigurableMixin } from "../../../mixins/configurable.js";
14
+ import { parse } from "./utils/parse.js";
15
+ import { zoom } from "./utils/zoom.js";
12
16
  const NS = 'query-builder';
13
17
  const Base = ConfigurableMixin(ResponsiveMixin(ThemeableMixin(TranslatableMixin(InferrableMixin(LitElement), NS))));
14
18
  /**
@@ -19,21 +23,28 @@ const Base = ConfigurableMixin(ResponsiveMixin(ThemeableMixin(TranslatableMixin(
19
23
  * @element foxy-query-builder
20
24
  * @since 1.12.0
21
25
  */
22
- class QueryBuilder extends Base {
26
+ export class QueryBuilder extends Base {
23
27
  constructor() {
24
28
  super(...arguments);
25
- /** List of reserved paths that should not be visible. */
29
+ /** Simple Mode will not show controls for these paths unless explicitly specified in options. */
26
30
  this.reservedPaths = ['zoom', 'limit', 'offset', 'order', 'fields'];
27
31
  /** If true, doesn't add `zoom` query parameter for complex paths. */
28
32
  this.disableZoom = false;
29
- /** If true, hides the UI for the "OR" operator in queries. */
33
+ /** If true, hides the UI for the "OR" operator in queries in the Advanced Mode. */
30
34
  this.disableOr = false;
31
35
  /** List of operators available in the builder UI. */
32
36
  this.operators = Object.values(Operator);
33
- /** Autocomplete suggestions. */
37
+ /** When provided, will display a documentation link in the Advanced Mode. */
38
+ this.docsHref = null;
39
+ /** Filter options in Simple Mode and autocomplete suggestions in Advanced Mode. */
34
40
  this.options = null;
35
41
  /** Current value as hAPI filter string. */
36
42
  this.value = null;
43
+ this.__isAdvancedMode = false;
44
+ }
45
+ /** Returns zoom value for a filter query. */
46
+ static zoom(value) {
47
+ return zoom(parse(value));
37
48
  }
38
49
  static get properties() {
39
50
  return {
@@ -42,36 +53,148 @@ class QueryBuilder extends Base {
42
53
  disableZoom: { type: Boolean, attribute: 'disable-zoom' },
43
54
  disableOr: { type: Boolean, attribute: 'disable-or' },
44
55
  operators: { type: Array },
56
+ docsHref: { attribute: 'docs-href' },
45
57
  options: { type: Array },
46
- value: { type: String },
58
+ value: {},
59
+ __isAdvancedMode: { attribute: false },
47
60
  };
48
61
  }
49
62
  static get styles() {
50
63
  return [super.styles, styles];
51
64
  }
52
65
  render() {
53
- var _a, _b, _c;
54
- const reservedPaths = new Set(this.reservedPaths);
55
- const hiddenValues = [];
56
- const visibleValues = [];
57
- parse((_a = this.value) !== null && _a !== void 0 ? _a : '').forEach(value => {
58
- const isVisible = Array.isArray(value) || !reservedPaths.has(value.path);
59
- isVisible ? visibleValues.push(value) : hiddenValues.push(value);
60
- });
61
- return Group({
62
- parsedValues: visibleValues,
63
- disableOr: this.disableOr,
64
- operators: (_b = this.operators) !== null && _b !== void 0 ? _b : [],
65
- disabled: this.disabled,
66
- readonly: this.readonly,
67
- options: (_c = this.options) !== null && _c !== void 0 ? _c : [],
68
- t: this.t.bind(this),
69
- onChange: newValue => {
70
- this.value = stringify([...newValue, ...hiddenValues], this.disableZoom);
71
- this.dispatchEvent(new QueryBuilder.ChangeEvent('change'));
72
- },
66
+ var _a, _b, _c, _d, _e, _f;
67
+ const isSimpleModeSupported = this.__isSimpleModeSupported;
68
+ const parsedValue = parse((_a = this.value) !== null && _a !== void 0 ? _a : '');
69
+ const operators = (_b = this.operators) !== null && _b !== void 0 ? _b : [];
70
+ const options = (_c = this.options) !== null && _c !== void 0 ? _c : [];
71
+ const t = this.t.bind(this);
72
+ const onChange = (newParsedValue) => {
73
+ this.value = stringify(newParsedValue, this.disableZoom);
74
+ this.dispatchEvent(new QueryBuilder.ChangeEvent('change'));
75
+ };
76
+ // This will trigger a re-render but is necessary to stay in the advanced mode once the support
77
+ // for simple mode is available again.
78
+ if (!isSimpleModeSupported && !this.__isAdvancedMode)
79
+ this.__isAdvancedMode = true;
80
+ return html `
81
+ <div class="space-y-m">
82
+ <div
83
+ class="grid grid-cols-2 gap-xs p-xs bg-contrast-5 rounded"
84
+ ?hidden=${!((_d = this.options) === null || _d === void 0 ? void 0 : _d.length)}
85
+ >
86
+ <label
87
+ class=${classMap({
88
+ 'p-xs rounded-s text-center font-medium transition-colors': true,
89
+ 'bg-base ring-1 ring-contrast-5': !this.__isAdvancedMode && isSimpleModeSupported,
90
+ 'hover-bg-contrast-5': this.__isAdvancedMode && isSimpleModeSupported,
91
+ 'focus-within-ring-2 focus-within-ring-inset focus-within-ring-primary-50': true,
92
+ 'cursor-pointer': isSimpleModeSupported,
93
+ 'text-disabled': !isSimpleModeSupported,
94
+ })}
95
+ >
96
+ <foxy-i18n infer="" key="mode_simple${isSimpleModeSupported ? '' : '_unsupported'}">
97
+ </foxy-i18n>
98
+ <input
99
+ class="sr-only"
100
+ type="radio"
101
+ name="mode"
102
+ ?disabled=${!isSimpleModeSupported}
103
+ ?checked=${!this.__isAdvancedMode}
104
+ @change=${() => (this.__isAdvancedMode = false)}
105
+ />
106
+ </label>
107
+
108
+ <label
109
+ class=${classMap({
110
+ 'p-xs rounded-s text-center font-medium cursor-pointer transition-colors': true,
111
+ 'bg-base ring-1 ring-contrast-5': this.__isAdvancedMode,
112
+ 'hover-bg-contrast-5': !this.__isAdvancedMode,
113
+ 'focus-within-ring-2 focus-within-ring-inset focus-within-ring-primary-50': true,
114
+ })}
115
+ >
116
+ <foxy-i18n infer="" key="mode_advanced"></foxy-i18n>
117
+ <input
118
+ class="sr-only"
119
+ type="radio"
120
+ name="mode"
121
+ ?checked=${this.__isAdvancedMode}
122
+ @change=${() => (this.__isAdvancedMode = true)}
123
+ />
124
+ </label>
125
+ </div>
126
+
127
+ ${this.__isAdvancedMode || !isSimpleModeSupported
128
+ ? html `
129
+ <p class="leading-s text-tertiary" ?hidden=${this.docsHref === null}>
130
+ <foxy-i18n infer="" key="advanced_mode_notice"></foxy-i18n>
131
+ <a
132
+ target="_blank"
133
+ class="cursor-pointer rounded-s text-secondary font-medium hover-underline focus-outline-none focus-ring-2 focus-ring-primary-50"
134
+ href=${ifDefined((_e = this.docsHref) !== null && _e !== void 0 ? _e : void 0)}
135
+ rel="nofollow noreferrer noopener"
136
+ >
137
+ <foxy-i18n infer="" key="api_reference_link"></foxy-i18n>
138
+ </a>
139
+ </p>
140
+
141
+ ${AdvancedGroup({
142
+ disableOr: this.disableOr,
143
+ disabled: this.disabled,
144
+ readonly: this.readonly,
145
+ rules: parsedValue,
146
+ operators,
147
+ onChange,
148
+ options,
149
+ t,
150
+ })}
151
+ `
152
+ : (_f = this.__simpleModeOptions) === null || _f === void 0 ? void 0 : _f.map(group => {
153
+ return SimpleGroup({
154
+ ...group,
155
+ disabled: this.disabled,
156
+ readonly: this.readonly,
157
+ rules: parsedValue,
158
+ onChange,
159
+ t,
160
+ });
161
+ })}
162
+ </div>
163
+ `;
164
+ }
165
+ get __isSimpleModeSupported() {
166
+ var _a;
167
+ if (this.options === null)
168
+ return false;
169
+ if (this.options.length === 0)
170
+ return false;
171
+ const parsedValue = parse((_a = this.value) !== null && _a !== void 0 ? _a : '');
172
+ if (parsedValue.length === 0)
173
+ return true;
174
+ return parsedValue.every(entry => {
175
+ var _a;
176
+ if (Array.isArray(entry))
177
+ return false;
178
+ if (entry.operator === Operator.In)
179
+ return false;
180
+ if (entry.operator === Operator.IsDefined && entry.value !== 'true')
181
+ return false;
182
+ return !!(this.reservedPaths.includes(entry.path) || ((_a = this.options) === null || _a === void 0 ? void 0 : _a.find(option => option.path === entry.path)));
73
183
  });
74
184
  }
185
+ get __simpleModeOptions() {
186
+ var _a;
187
+ return (_a = this.options) === null || _a === void 0 ? void 0 : _a.reduce((result, option) => {
188
+ const group = result.find(group => { var _a; return group.name === ((_a = option.group) === null || _a === void 0 ? void 0 : _a.name); });
189
+ if (group) {
190
+ group.options.push(option);
191
+ }
192
+ else {
193
+ result.push({ ...option.group, options: [option] });
194
+ }
195
+ return result;
196
+ }, []);
197
+ }
75
198
  }
76
199
  /** QueryBuilder dispatches this event on itself when value changes. */
77
200
  QueryBuilder.ChangeEvent = class extends CustomEvent {
@@ -80,5 +203,4 @@ QueryBuilder.ChangeEvent = class extends CustomEvent {
80
203
  QueryBuilder.Operator = Operator;
81
204
  /** Field type dictionary for use in autocomplete options. */
82
205
  QueryBuilder.Type = Type;
83
- export { QueryBuilder };
84
206
  //# sourceMappingURL=QueryBuilder.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"QueryBuilder.js","sourceRoot":"","sources":["../../../../src/elements/public/QueryBuilder/QueryBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import { CSSResultArray, LitElement, PropertyDeclarations, TemplateResult } from 'lit-element';\nimport { ParsedValue, Operator, Option, Type } from './types';\n\nimport { Group } from './components/Group';\nimport { ResponsiveMixin } from '../../../mixins/responsive';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { parse } from './utils/parse';\nimport { stringify } from './utils/stringify';\nimport { styles } from './styles';\nimport { InferrableMixin } from '../../../mixins/inferrable';\nimport { ConfigurableMixin } from '../../../mixins/configurable';\n\nconst NS = 'query-builder';\nconst Base = ConfigurableMixin(\n ResponsiveMixin(ThemeableMixin(TranslatableMixin(InferrableMixin(LitElement), NS)))\n);\n\n/**\n * UI component for creating Foxy hAPI filters visually. Compatible with\n * Backend API, Customer API or any other API using the same format as described\n * in our [docs](https://api.foxy.io/docs/cheat-sheet).\n *\n * @element foxy-query-builder\n * @since 1.12.0\n */\nclass QueryBuilder extends Base {\n /** QueryBuilder dispatches this event on itself when value changes. */\n static readonly ChangeEvent = class extends CustomEvent<void> {};\n\n /** Operator dictionary for use in autocomplete options. */\n static readonly Operator = Operator;\n\n /** Field type dictionary for use in autocomplete options. */\n static readonly Type = Type;\n\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n reservedPaths: { type: Array, attribute: 'reserved-paths' },\n disableZoom: { type: Boolean, attribute: 'disable-zoom' },\n disableOr: { type: Boolean, attribute: 'disable-or' },\n operators: { type: Array },\n options: { type: Array },\n value: { type: String },\n };\n }\n\n static get styles(): CSSResultArray {\n return [super.styles, styles];\n }\n\n /** List of reserved paths that should not be visible. */\n reservedPaths: string[] = ['zoom', 'limit', 'offset', 'order', 'fields'];\n\n /** If true, doesn't add `zoom` query parameter for complex paths. */\n disableZoom = false;\n\n /** If true, hides the UI for the \"OR\" operator in queries. */\n disableOr = false;\n\n /** List of operators available in the builder UI. */\n operators: Operator[] = Object.values(Operator);\n\n /** Autocomplete suggestions. */\n options: Option[] | null = null;\n\n /** Current value as hAPI filter string. */\n value: string | null = null;\n\n render(): TemplateResult {\n const reservedPaths = new Set(this.reservedPaths);\n const hiddenValues: (ParsedValue | ParsedValue[])[] = [];\n const visibleValues: (ParsedValue | ParsedValue[])[] = [];\n\n parse(this.value ?? '').forEach(value => {\n const isVisible = Array.isArray(value) || !reservedPaths.has(value.path);\n isVisible ? visibleValues.push(value) : hiddenValues.push(value);\n });\n\n return Group({\n parsedValues: visibleValues,\n disableOr: this.disableOr,\n operators: this.operators ?? [],\n disabled: this.disabled,\n readonly: this.readonly,\n options: this.options ?? [],\n t: this.t.bind(this),\n onChange: newValue => {\n this.value = stringify([...newValue, ...hiddenValues], this.disableZoom);\n this.dispatchEvent(new QueryBuilder.ChangeEvent('change'));\n },\n });\n }\n}\n\nexport { QueryBuilder };\n"]}
1
+ {"version":3,"file":"QueryBuilder.js","sourceRoot":"","sources":["../../../../src/elements/public/QueryBuilder/QueryBuilder.ts"],"names":[],"mappings":"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","sourcesContent":["import type { CSSResultArray, PropertyDeclarations, TemplateResult } from 'lit-element';\nimport type { Rule, Option } from './types';\n\nimport { TranslatableMixin } from '../../../mixins/translatable';\nimport { ConfigurableMixin } from '../../../mixins/configurable';\nimport { html, LitElement } from 'lit-element';\nimport { InferrableMixin } from '../../../mixins/inferrable';\nimport { ResponsiveMixin } from '../../../mixins/responsive';\nimport { ThemeableMixin } from '../../../mixins/themeable';\nimport { Operator, Type } from './types';\nimport { AdvancedGroup } from './components/AdvancedGroup';\nimport { SimpleGroup } from './components/SimpleGroup';\nimport { stringify } from './utils/stringify';\nimport { ifDefined } from 'lit-html/directives/if-defined';\nimport { classMap } from '../../../utils/class-map';\nimport { styles } from './styles';\nimport { parse } from './utils/parse';\nimport { zoom } from './utils/zoom';\n\nconst NS = 'query-builder';\nconst Base = ConfigurableMixin(\n ResponsiveMixin(ThemeableMixin(TranslatableMixin(InferrableMixin(LitElement), NS)))\n);\n\n/**\n * UI component for creating Foxy hAPI filters visually. Compatible with\n * Backend API, Customer API or any other API using the same format as described\n * in our [docs](https://api.foxy.io/docs/cheat-sheet).\n *\n * @element foxy-query-builder\n * @since 1.12.0\n */\nexport class QueryBuilder extends Base {\n /** QueryBuilder dispatches this event on itself when value changes. */\n static readonly ChangeEvent = class extends CustomEvent<void> {};\n\n /** Operator dictionary for use in autocomplete options. */\n static readonly Operator = Operator;\n\n /** Field type dictionary for use in autocomplete options. */\n static readonly Type = Type;\n\n /** Returns zoom value for a filter query. */\n static zoom(value: string): string {\n return zoom(parse(value));\n }\n\n static get properties(): PropertyDeclarations {\n return {\n ...super.properties,\n reservedPaths: { type: Array, attribute: 'reserved-paths' },\n disableZoom: { type: Boolean, attribute: 'disable-zoom' },\n disableOr: { type: Boolean, attribute: 'disable-or' },\n operators: { type: Array },\n docsHref: { attribute: 'docs-href' },\n options: { type: Array },\n value: {},\n __isAdvancedMode: { attribute: false },\n };\n }\n\n static get styles(): CSSResultArray {\n return [super.styles, styles];\n }\n\n /** Simple Mode will not show controls for these paths unless explicitly specified in options. */\n reservedPaths: string[] = ['zoom', 'limit', 'offset', 'order', 'fields'];\n\n /** If true, doesn't add `zoom` query parameter for complex paths. */\n disableZoom = false;\n\n /** If true, hides the UI for the \"OR\" operator in queries in the Advanced Mode. */\n disableOr = false;\n\n /** List of operators available in the builder UI. */\n operators: Operator[] = Object.values(Operator);\n\n /** When provided, will display a documentation link in the Advanced Mode. */\n docsHref: string | null = null;\n\n /** Filter options in Simple Mode and autocomplete suggestions in Advanced Mode. */\n options: Option[] | null = null;\n\n /** Current value as hAPI filter string. */\n value: string | null = null;\n\n private __isAdvancedMode = false;\n\n render(): TemplateResult {\n const isSimpleModeSupported = this.__isSimpleModeSupported;\n const parsedValue = parse(this.value ?? '');\n const operators = this.operators ?? [];\n const options = this.options ?? [];\n const t = this.t.bind(this);\n\n const onChange = (newParsedValue: (Rule | Rule[])[]) => {\n this.value = stringify(newParsedValue, this.disableZoom);\n this.dispatchEvent(new QueryBuilder.ChangeEvent('change'));\n };\n\n // This will trigger a re-render but is necessary to stay in the advanced mode once the support\n // for simple mode is available again.\n if (!isSimpleModeSupported && !this.__isAdvancedMode) this.__isAdvancedMode = true;\n\n return html`\n <div class=\"space-y-m\">\n <div\n class=\"grid grid-cols-2 gap-xs p-xs bg-contrast-5 rounded\"\n ?hidden=${!this.options?.length}\n >\n <label\n class=${classMap({\n 'p-xs rounded-s text-center font-medium transition-colors': true,\n 'bg-base ring-1 ring-contrast-5': !this.__isAdvancedMode && isSimpleModeSupported,\n 'hover-bg-contrast-5': this.__isAdvancedMode && isSimpleModeSupported,\n 'focus-within-ring-2 focus-within-ring-inset focus-within-ring-primary-50': true,\n 'cursor-pointer': isSimpleModeSupported,\n 'text-disabled': !isSimpleModeSupported,\n })}\n >\n <foxy-i18n infer=\"\" key=\"mode_simple${isSimpleModeSupported ? '' : '_unsupported'}\">\n </foxy-i18n>\n <input\n class=\"sr-only\"\n type=\"radio\"\n name=\"mode\"\n ?disabled=${!isSimpleModeSupported}\n ?checked=${!this.__isAdvancedMode}\n @change=${() => (this.__isAdvancedMode = false)}\n />\n </label>\n\n <label\n class=${classMap({\n 'p-xs rounded-s text-center font-medium cursor-pointer transition-colors': true,\n 'bg-base ring-1 ring-contrast-5': this.__isAdvancedMode,\n 'hover-bg-contrast-5': !this.__isAdvancedMode,\n 'focus-within-ring-2 focus-within-ring-inset focus-within-ring-primary-50': true,\n })}\n >\n <foxy-i18n infer=\"\" key=\"mode_advanced\"></foxy-i18n>\n <input\n class=\"sr-only\"\n type=\"radio\"\n name=\"mode\"\n ?checked=${this.__isAdvancedMode}\n @change=${() => (this.__isAdvancedMode = true)}\n />\n </label>\n </div>\n\n ${this.__isAdvancedMode || !isSimpleModeSupported\n ? html`\n <p class=\"leading-s text-tertiary\" ?hidden=${this.docsHref === null}>\n <foxy-i18n infer=\"\" key=\"advanced_mode_notice\"></foxy-i18n>\n <a\n target=\"_blank\"\n class=\"cursor-pointer rounded-s text-secondary font-medium hover-underline focus-outline-none focus-ring-2 focus-ring-primary-50\"\n href=${ifDefined(this.docsHref ?? void 0)}\n rel=\"nofollow noreferrer noopener\"\n >\n <foxy-i18n infer=\"\" key=\"api_reference_link\"></foxy-i18n>\n </a>\n </p>\n\n ${AdvancedGroup({\n disableOr: this.disableOr,\n disabled: this.disabled,\n readonly: this.readonly,\n rules: parsedValue,\n operators,\n onChange,\n options,\n t,\n })}\n `\n : this.__simpleModeOptions?.map(group => {\n return SimpleGroup({\n ...group,\n disabled: this.disabled,\n readonly: this.readonly,\n rules: parsedValue as Rule[],\n onChange,\n t,\n });\n })}\n </div>\n `;\n }\n\n private get __isSimpleModeSupported() {\n if (this.options === null) return false;\n if (this.options.length === 0) return false;\n\n const parsedValue = parse(this.value ?? '');\n if (parsedValue.length === 0) return true;\n\n return parsedValue.every(entry => {\n if (Array.isArray(entry)) return false;\n if (entry.operator === Operator.In) return false;\n if (entry.operator === Operator.IsDefined && entry.value !== 'true') return false;\n return !!(\n this.reservedPaths.includes(entry.path) ||\n this.options?.find(option => option.path === entry.path)\n );\n });\n }\n\n private get __simpleModeOptions() {\n return this.options?.reduce((result, option) => {\n const group = result.find(group => group.name === option.group?.name);\n\n if (group) {\n group.options.push(option);\n } else {\n result.push({ ...option.group, options: [option] });\n }\n\n return result;\n }, [] as { name?: string; layout?: string; options: Option[] }[]);\n }\n}\n"]}
@@ -0,0 +1,16 @@
1
+ import type { Operator, Option, Rule } from '../types';
2
+ import type { TemplateResult } from 'lit-html';
3
+ import type { I18n } from '../../I18n/I18n';
4
+ declare type Params = {
5
+ operators: Operator[];
6
+ disableOr: boolean;
7
+ isNested?: boolean;
8
+ disabled: boolean;
9
+ readonly: boolean;
10
+ options: Option[];
11
+ rules: (Rule | Rule[])[];
12
+ t: I18n['t'];
13
+ onChange: (newValue: (Rule | Rule[])[]) => void;
14
+ };
15
+ export declare function AdvancedGroup(params: Params): TemplateResult;
16
+ export {};
@@ -0,0 +1,78 @@
1
+ import { AdvancedRule } from "./AdvancedRule.js";
2
+ import { repeat } from 'lit-html/directives/repeat';
3
+ import { html } from 'lit-html';
4
+ export function AdvancedGroup(params) {
5
+ const hasNestedRules = params.rules.some(v => Array.isArray(v));
6
+ const andDivider = html `<div class=${hasNestedRules ? 'h-xs' : 'mt-s'}></div>`;
7
+ const orDivider = html `
8
+ <div class="flex items-center h-s">
9
+ <div class="w-m text-center leading-none uppercase font-medium text-xs text-contrast-30">
10
+ ${params.t('or')}
11
+ </div>
12
+
13
+ <div class="flex-1 border-t border-contrast-20"></div>
14
+ <div class="w-m ml-s flex-shrink-0"></div>
15
+ <div class="hidden sm-block w-m flex-shrink-0"></div>
16
+ </div>
17
+ `;
18
+ return html `
19
+ <div aria-label=${params.t('query_builder_group')}>
20
+ ${repeat([...params.rules, null], (rule, ruleIndex) => String(ruleIndex), (rule, ruleIndex) => {
21
+ const divider = ruleIndex > 0 ? (params.isNested ? orDivider : andDivider) : '';
22
+ if (rule === null) {
23
+ return [
24
+ divider,
25
+ AdvancedRule({
26
+ ...params,
27
+ rule: { path: '', operator: null, value: '' },
28
+ isFullSize: !params.isNested && params.rules.length === 0,
29
+ onChange: newValue => params.onChange([...params.rules, newValue]),
30
+ }),
31
+ ];
32
+ }
33
+ if (Array.isArray(rule)) {
34
+ return [
35
+ divider,
36
+ html `
37
+ <div class="bg-contrast-10 rounded-t-l rounded-b-l p-s -m-s">
38
+ ${AdvancedGroup({
39
+ ...params,
40
+ rules: rule,
41
+ isNested: true,
42
+ onChange: newRule => {
43
+ const newValue = [...params.rules];
44
+ const typedNewRule = newRule;
45
+ newValue[ruleIndex] = newRule.length > 1 ? typedNewRule : typedNewRule[0];
46
+ params.onChange(newValue);
47
+ },
48
+ })}
49
+ </div>
50
+ `,
51
+ ];
52
+ }
53
+ return [
54
+ divider,
55
+ AdvancedRule({
56
+ ...params,
57
+ rule: rule,
58
+ onChange: newValue => {
59
+ const newRules = [...params.rules];
60
+ newRules[ruleIndex] = newValue;
61
+ params.onChange(newRules);
62
+ },
63
+ onDelete: () => {
64
+ const newRules = params.rules.filter((_, i) => i !== ruleIndex);
65
+ params.onChange(newRules);
66
+ },
67
+ onConvert: () => {
68
+ const newRules = [...params.rules];
69
+ newRules[ruleIndex] = [rule, { ...rule, operator: null, value: '' }];
70
+ params.onChange(newRules);
71
+ },
72
+ }),
73
+ ];
74
+ })}
75
+ </div>
76
+ `;
77
+ }
78
+ //# sourceMappingURL=AdvancedGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdvancedGroup.js","sourceRoot":"","sources":["../../../../../src/elements/public/QueryBuilder/components/AdvancedGroup.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Operator, Option, Rule } from '../types';\nimport type { TemplateResult } from 'lit-html';\nimport type { I18n } from '../../I18n/I18n';\n\nimport { AdvancedRule } from './AdvancedRule';\nimport { repeat } from 'lit-html/directives/repeat';\nimport { html } from 'lit-html';\n\ntype Params = {\n operators: Operator[];\n disableOr: boolean;\n isNested?: boolean;\n disabled: boolean;\n readonly: boolean;\n options: Option[];\n rules: (Rule | Rule[])[];\n t: I18n['t'];\n onChange: (newValue: (Rule | Rule[])[]) => void;\n};\n\nexport function AdvancedGroup(params: Params): TemplateResult {\n const hasNestedRules = params.rules.some(v => Array.isArray(v));\n const andDivider = html`<div class=${hasNestedRules ? 'h-xs' : 'mt-s'}></div>`;\n const orDivider = html`\n <div class=\"flex items-center h-s\">\n <div class=\"w-m text-center leading-none uppercase font-medium text-xs text-contrast-30\">\n ${params.t('or')}\n </div>\n\n <div class=\"flex-1 border-t border-contrast-20\"></div>\n <div class=\"w-m ml-s flex-shrink-0\"></div>\n <div class=\"hidden sm-block w-m flex-shrink-0\"></div>\n </div>\n `;\n\n return html`\n <div aria-label=${params.t('query_builder_group')}>\n ${repeat(\n [...params.rules, null],\n (rule, ruleIndex) => String(ruleIndex),\n (rule, ruleIndex) => {\n const divider = ruleIndex > 0 ? (params.isNested ? orDivider : andDivider) : '';\n\n if (rule === null) {\n return [\n divider,\n AdvancedRule({\n ...params,\n rule: { path: '', operator: null, value: '' },\n isFullSize: !params.isNested && params.rules.length === 0,\n onChange: newValue => params.onChange([...params.rules, newValue]),\n }),\n ];\n }\n\n if (Array.isArray(rule)) {\n return [\n divider,\n html`\n <div class=\"bg-contrast-10 rounded-t-l rounded-b-l p-s -m-s\">\n ${AdvancedGroup({\n ...params,\n rules: rule,\n isNested: true,\n onChange: newRule => {\n const newValue = [...params.rules];\n const typedNewRule = newRule as Rule[];\n newValue[ruleIndex] = newRule.length > 1 ? typedNewRule : typedNewRule[0];\n params.onChange(newValue);\n },\n })}\n </div>\n `,\n ];\n }\n\n return [\n divider,\n AdvancedRule({\n ...params,\n rule: rule,\n onChange: newValue => {\n const newRules = [...params.rules];\n newRules[ruleIndex] = newValue;\n params.onChange(newRules);\n },\n onDelete: () => {\n const newRules = params.rules.filter((_, i) => i !== ruleIndex);\n params.onChange(newRules);\n },\n onConvert: () => {\n const newRules = [...params.rules];\n newRules[ruleIndex] = [rule, { ...rule, operator: null, value: '' }];\n params.onChange(newRules);\n },\n }),\n ];\n }\n )}\n </div>\n `;\n}\n"]}
@@ -0,0 +1,12 @@
1
+ import type { TemplateResult } from 'lit-html';
2
+ import type { I18n } from '../../I18n/I18n';
3
+ declare type Params = {
4
+ disabled: boolean;
5
+ readonly: boolean;
6
+ label: string;
7
+ value: string;
8
+ t: I18n['t'];
9
+ onChange: (newValue: string) => void;
10
+ };
11
+ export declare function AdvancedInput(params: Params): TemplateResult;
12
+ export {};
@@ -0,0 +1,50 @@
1
+ import { classMap } from "../../../../utils/class-map.js";
2
+ import { html } from 'lit-html';
3
+ export function AdvancedInput(params) {
4
+ return html `
5
+ <label class="relative flex items-center cursor-text group text-tertiary">
6
+ <div class="relative flex-1 min-w-0 overflow-hidden">
7
+ <input
8
+ placeholder=${params.t(params.label)}
9
+ class=${classMap({
10
+ 'bg-base relative flex h-m px-s font-medium w-full': true,
11
+ 'text-body': !params.disabled && !params.readonly,
12
+ 'text-disabled': params.disabled,
13
+ 'text-secondary': params.readonly,
14
+ 'flex max-w-full whitespace-nowrap': true,
15
+ 'focus-outline-none': true,
16
+ })}
17
+ .value=${params.value}
18
+ ?disabled=${params.disabled || params.readonly}
19
+ @keydown=${(evt) => evt.key === '|' && evt.preventDefault()}
20
+ @input=${(evt) => {
21
+ const input = evt.currentTarget;
22
+ params.onChange(input.value.replace(/\|/gi, ''));
23
+ }}
24
+ />
25
+ </div>
26
+
27
+ <span
28
+ class=${classMap({
29
+ 'font-tnum text-xs font-medium border border-current mr-s px-xs rounded-s': true,
30
+ 'inline-block': !!params.value,
31
+ 'sr-only': !params.value,
32
+ 'text-body': !params.disabled && !params.readonly,
33
+ 'text-disabled': params.disabled,
34
+ 'text-secondary': params.readonly,
35
+ })}
36
+ >
37
+ ${params.t(params.label)}
38
+ </span>
39
+
40
+ ${params.disabled || params.readonly
41
+ ? ''
42
+ : html `
43
+ <div
44
+ class="absolute inset-0 transition-colors bg-transparent group-hover-bg-contrast-5 pointer-events-none"
45
+ ></div>
46
+ `}
47
+ </label>
48
+ `;
49
+ }
50
+ //# sourceMappingURL=AdvancedInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdvancedInput.js","sourceRoot":"","sources":["../../../../../src/elements/public/QueryBuilder/components/AdvancedInput.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,QAAQ,EAAE,uCAAoC;AACvD,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAWhC,MAAM,UAAU,aAAa,CAAC,MAAc;IAC1C,OAAO,IAAI,CAAA;;;;wBAIW,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;kBAC5B,QAAQ,CAAC;QACf,mDAAmD,EAAE,IAAI;QACzD,WAAW,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ;QACjD,eAAe,EAAE,MAAM,CAAC,QAAQ;QAChC,gBAAgB,EAAE,MAAM,CAAC,QAAQ;QACjC,mCAAmC,EAAE,IAAI;QACzC,oBAAoB,EAAE,IAAI;KAC3B,CAAC;mBACO,MAAM,CAAC,KAAK;sBACT,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ;qBACnC,CAAC,GAAkB,EAAE,EAAE,CAAC,GAAG,CAAC,GAAG,KAAK,GAAG,IAAI,GAAG,CAAC,cAAc,EAAE;mBACjE,CAAC,GAAU,EAAE,EAAE;QACtB,MAAM,KAAK,GAAG,GAAG,CAAC,aAAiC,CAAC;QACpD,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC;IACnD,CAAC;;;;;gBAKK,QAAQ,CAAC;QACf,0EAA0E,EAAE,IAAI;QAChF,cAAc,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK;QAC9B,SAAS,EAAE,CAAC,MAAM,CAAC,KAAK;QACxB,WAAW,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,CAAC,MAAM,CAAC,QAAQ;QACjD,eAAe,EAAE,MAAM,CAAC,QAAQ;QAChC,gBAAgB,EAAE,MAAM,CAAC,QAAQ;KAClC,CAAC;;UAEA,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;;;QAGxB,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,QAAQ;QAClC,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,IAAI,CAAA;;;;WAIH;;GAER,CAAC;AACJ,CAAC","sourcesContent":["import type { TemplateResult } from 'lit-html';\nimport type { I18n } from '../../I18n/I18n';\n\nimport { classMap } from '../../../../utils/class-map';\nimport { html } from 'lit-html';\n\ntype Params = {\n disabled: boolean;\n readonly: boolean;\n label: string;\n value: string;\n t: I18n['t'];\n onChange: (newValue: string) => void;\n};\n\nexport function AdvancedInput(params: Params): TemplateResult {\n return html`\n <label class=\"relative flex items-center cursor-text group text-tertiary\">\n <div class=\"relative flex-1 min-w-0 overflow-hidden\">\n <input\n placeholder=${params.t(params.label)}\n class=${classMap({\n 'bg-base relative flex h-m px-s font-medium w-full': true,\n 'text-body': !params.disabled && !params.readonly,\n 'text-disabled': params.disabled,\n 'text-secondary': params.readonly,\n 'flex max-w-full whitespace-nowrap': true, // ugh safari\n 'focus-outline-none': true,\n })}\n .value=${params.value}\n ?disabled=${params.disabled || params.readonly}\n @keydown=${(evt: KeyboardEvent) => evt.key === '|' && evt.preventDefault()}\n @input=${(evt: Event) => {\n const input = evt.currentTarget as HTMLInputElement;\n params.onChange(input.value.replace(/\\|/gi, ''));\n }}\n />\n </div>\n\n <span\n class=${classMap({\n 'font-tnum text-xs font-medium border border-current mr-s px-xs rounded-s': true,\n 'inline-block': !!params.value,\n 'sr-only': !params.value,\n 'text-body': !params.disabled && !params.readonly,\n 'text-disabled': params.disabled,\n 'text-secondary': params.readonly,\n })}\n >\n ${params.t(params.label)}\n </span>\n\n ${params.disabled || params.readonly\n ? ''\n : html`\n <div\n class=\"absolute inset-0 transition-colors bg-transparent group-hover-bg-contrast-5 pointer-events-none\"\n ></div>\n `}\n </label>\n `;\n}\n"]}
@@ -0,0 +1,14 @@
1
+ import type { TemplateResult } from 'lit-html';
2
+ import type { Rule } from '../types';
3
+ import type { I18n } from '../../I18n/I18n';
4
+ import { Operator } from '../types';
5
+ declare type Params = {
6
+ operators: Operator[];
7
+ readonly: boolean;
8
+ disabled: boolean;
9
+ rule: Rule;
10
+ t: I18n['t'];
11
+ onChange: (newValue: Rule) => void;
12
+ };
13
+ export declare function AdvancedOperatorToggle(params: Params): TemplateResult;
14
+ export {};
@@ -0,0 +1,41 @@
1
+ import * as icons from "../icons/index.js";
2
+ import { classMap } from "../../../../utils/class-map.js";
3
+ import { Operator } from "../types.js";
4
+ import { html } from 'lit-html';
5
+ export function AdvancedOperatorToggle(params) {
6
+ const { rule, operators, disabled, readonly, t, onChange } = params;
7
+ const { operator, value, path, name } = rule;
8
+ const operatorToIcon = {
9
+ [Operator.GreaterThan]: icons.operatorGreaterThan,
10
+ [Operator.GreaterThanOrEqual]: icons.operatorGreaterThanOrEqual,
11
+ [Operator.In]: icons.operatorIn,
12
+ [Operator.IsDefined]: icons.operatorIsDefined,
13
+ [Operator.LessThan]: icons.operatorLessThan,
14
+ [Operator.LessThanOrEqual]: icons.operatorLessThanOrEqual,
15
+ [Operator.Not]: icons.operatorNot,
16
+ };
17
+ const availableOperators = Object.values(Operator).filter(v => operators.includes(v) && (name ? true : v !== Operator.IsDefined));
18
+ const isDisabled = disabled || readonly || !availableOperators.length || !path;
19
+ return html `
20
+ <button
21
+ title=${t(`operator_${operator !== null && operator !== void 0 ? operator : 'equal'}`)}
22
+ class=${classMap({
23
+ 'flex items-center justify-center w-m h-m transition-colors': true,
24
+ 'focus-outline-none focus-ring-2 focus-ring-inset focus-ring-primary-50': true,
25
+ 'text-body hover-bg-contrast-5': !isDisabled && availableOperators.length > 1,
26
+ 'cursor-default text-tertiary': !isDisabled && availableOperators.length <= 1,
27
+ 'text-disabled cursor-default': isDisabled,
28
+ })}
29
+ ?disabled=${isDisabled || availableOperators.length <= 1}
30
+ @click=${() => {
31
+ var _a;
32
+ const newOperatorIndex = operator ? availableOperators.indexOf(operator) : -1;
33
+ const newOperator = (_a = availableOperators[newOperatorIndex + 1]) !== null && _a !== void 0 ? _a : null;
34
+ onChange({ ...rule, operator: newOperator, value: value });
35
+ }}
36
+ >
37
+ <div aria-hidden="true">${operator ? operatorToIcon[operator] : icons.operatorEqual}</div>
38
+ </button>
39
+ `;
40
+ }
41
+ //# sourceMappingURL=AdvancedOperatorToggle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdvancedOperatorToggle.js","sourceRoot":"","sources":["../../../../../src/elements/public/QueryBuilder/components/AdvancedOperatorToggle.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,KAAK,0BAAuB;AAExC,OAAO,EAAE,QAAQ,EAAE,uCAAoC;AACvD,OAAO,EAAE,QAAQ,EAAE,oBAAiB;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,UAAU,CAAC;AAWhC,MAAM,UAAU,sBAAsB,CAAC,MAAc;IACnD,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,EAAE,GAAG,MAAM,CAAC;IACpE,MAAM,EAAE,QAAQ,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC;IAE7C,MAAM,cAAc,GAAsC;QACxD,CAAC,QAAQ,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,mBAAmB;QACjD,CAAC,QAAQ,CAAC,kBAAkB,CAAC,EAAE,KAAK,CAAC,0BAA0B;QAC/D,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE,KAAK,CAAC,UAAU;QAC/B,CAAC,QAAQ,CAAC,SAAS,CAAC,EAAE,KAAK,CAAC,iBAAiB;QAC7C,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC,gBAAgB;QAC3C,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,KAAK,CAAC,uBAAuB;QACzD,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,KAAK,CAAC,WAAW;KAClC,CAAC;IAEF,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,MAAM,CACvD,CAAC,CAAC,EAAE,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,SAAS,CAAC,CACvE,CAAC;IAEF,MAAM,UAAU,GAAG,QAAQ,IAAI,QAAQ,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC;IAE/E,OAAO,IAAI,CAAA;;cAEC,CAAC,CAAC,YAAY,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,OAAO,EAAE,CAAC;cACpC,QAAQ,CAAC;QACf,4DAA4D,EAAE,IAAI;QAClE,wEAAwE,EAAE,IAAI;QAC9E,+BAA+B,EAAE,CAAC,UAAU,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC;QAC7E,8BAA8B,EAAE,CAAC,UAAU,IAAI,kBAAkB,CAAC,MAAM,IAAI,CAAC;QAC7E,8BAA8B,EAAE,UAAU;KAC3C,CAAC;kBACU,UAAU,IAAI,kBAAkB,CAAC,MAAM,IAAI,CAAC;eAC/C,GAAG,EAAE;;QACZ,MAAM,gBAAgB,GAAG,QAAQ,CAAC,CAAC,CAAC,kBAAkB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,MAAM,WAAW,SAAG,kBAAkB,CAAC,gBAAgB,GAAG,CAAC,CAAC,mCAAI,IAAI,CAAC;QACrE,QAAQ,CAAC,EAAE,GAAG,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC;IAC7D,CAAC;;gCAEyB,QAAQ,CAAC,CAAC,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa;;GAEtF,CAAC;AACJ,CAAC","sourcesContent":["import type { SVGTemplateResult, TemplateResult } from 'lit-html';\nimport type { Rule } from '../types';\nimport type { I18n } from '../../I18n/I18n';\n\nimport * as icons from '../icons/index';\n\nimport { classMap } from '../../../../utils/class-map';\nimport { Operator } from '../types';\nimport { html } from 'lit-html';\n\ntype Params = {\n operators: Operator[];\n readonly: boolean;\n disabled: boolean;\n rule: Rule;\n t: I18n['t'];\n onChange: (newValue: Rule) => void;\n};\n\nexport function AdvancedOperatorToggle(params: Params): TemplateResult {\n const { rule, operators, disabled, readonly, t, onChange } = params;\n const { operator, value, path, name } = rule;\n\n const operatorToIcon: Record<string, SVGTemplateResult> = {\n [Operator.GreaterThan]: icons.operatorGreaterThan,\n [Operator.GreaterThanOrEqual]: icons.operatorGreaterThanOrEqual,\n [Operator.In]: icons.operatorIn,\n [Operator.IsDefined]: icons.operatorIsDefined,\n [Operator.LessThan]: icons.operatorLessThan,\n [Operator.LessThanOrEqual]: icons.operatorLessThanOrEqual,\n [Operator.Not]: icons.operatorNot,\n };\n\n const availableOperators = Object.values(Operator).filter(\n v => operators.includes(v) && (name ? true : v !== Operator.IsDefined)\n );\n\n const isDisabled = disabled || readonly || !availableOperators.length || !path;\n\n return html`\n <button\n title=${t(`operator_${operator ?? 'equal'}`)}\n class=${classMap({\n 'flex items-center justify-center w-m h-m transition-colors': true,\n 'focus-outline-none focus-ring-2 focus-ring-inset focus-ring-primary-50': true,\n 'text-body hover-bg-contrast-5': !isDisabled && availableOperators.length > 1,\n 'cursor-default text-tertiary': !isDisabled && availableOperators.length <= 1,\n 'text-disabled cursor-default': isDisabled,\n })}\n ?disabled=${isDisabled || availableOperators.length <= 1}\n @click=${() => {\n const newOperatorIndex = operator ? availableOperators.indexOf(operator) : -1;\n const newOperator = availableOperators[newOperatorIndex + 1] ?? null;\n onChange({ ...rule, operator: newOperator, value: value });\n }}\n >\n <div aria-hidden=\"true\">${operator ? operatorToIcon[operator] : icons.operatorEqual}</div>\n </button>\n `;\n}\n"]}
@@ -0,0 +1,18 @@
1
+ import type { TemplateResult } from 'lit-html';
2
+ import type { Operator, Rule } from '../types';
3
+ import type { I18n } from '../../I18n/I18n';
4
+ declare type Params = {
5
+ isFullSize?: boolean;
6
+ isNested?: boolean;
7
+ operators: Operator[];
8
+ disableOr: boolean;
9
+ readonly: boolean;
10
+ disabled: boolean;
11
+ rule: Rule;
12
+ t: I18n['t'];
13
+ onConvert?: () => void;
14
+ onDelete?: () => void;
15
+ onChange: (newValue: Rule) => void;
16
+ };
17
+ export declare function AdvancedRule(params: Params): TemplateResult;
18
+ export {};