@salla.sa/twilight-components 2.13.18 → 2.13.19

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 (238) hide show
  1. package/dist/cjs/{camera-807a5122.js → camera-82e553eb.js} +1 -9
  2. package/dist/cjs/camera-82e553eb.js.map +1 -0
  3. package/dist/cjs/check-771d889f.js +15 -0
  4. package/dist/cjs/check-771d889f.js.map +1 -0
  5. package/dist/cjs/{index-40f35e63.js → index-96c545df.js} +12 -3
  6. package/dist/cjs/index-96c545df.js.map +1 -0
  7. package/dist/cjs/loader.cjs.js +2 -2
  8. package/dist/cjs/salla-add-product-button_47.cjs.entry.js +4 -3
  9. package/dist/cjs/salla-add-product-button_47.cjs.entry.js.map +1 -1
  10. package/dist/cjs/salla-advertisement.cjs.entry.js +1 -1
  11. package/dist/cjs/salla-app-install-alert.cjs.entry.js +10 -20
  12. package/dist/cjs/salla-app-install-alert.cjs.entry.js.map +1 -1
  13. package/dist/cjs/salla-apps-icons.cjs.entry.js +1 -1
  14. package/dist/cjs/salla-conditional-fields.cjs.entry.js +1 -1
  15. package/dist/cjs/salla-contacts.cjs.entry.js +1 -1
  16. package/dist/cjs/salla-filters-widget.cjs.entry.js +1 -1
  17. package/dist/cjs/salla-filters.cjs.entry.js +1 -1
  18. package/dist/cjs/salla-installment.cjs.entry.js +1 -1
  19. package/dist/cjs/salla-loyalty-prize-item.cjs.entry.js +1 -1
  20. package/dist/cjs/salla-notification-item.cjs.entry.js +1 -1
  21. package/dist/cjs/salla-notifications.cjs.entry.js +1 -1
  22. package/dist/cjs/salla-offer.cjs.entry.js +1 -1
  23. package/dist/cjs/salla-order-summary.cjs.entry.js +107 -0
  24. package/dist/cjs/salla-order-summary.cjs.entry.js.map +1 -0
  25. package/dist/cjs/salla-payments.cjs.entry.js +1 -1
  26. package/dist/cjs/salla-price-range.cjs.entry.js +1 -1
  27. package/dist/cjs/salla-product-options.cjs.entry.js +4 -3
  28. package/dist/cjs/salla-product-options.cjs.entry.js.map +1 -1
  29. package/dist/cjs/salla-products-list.cjs.entry.js +1 -1
  30. package/dist/cjs/salla-products-slider.cjs.entry.js +1 -1
  31. package/dist/cjs/salla-social.cjs.entry.js +1 -1
  32. package/dist/cjs/twilight.cjs.js +2 -2
  33. package/dist/collection/collection-manifest.json +1 -0
  34. package/dist/collection/components/salla-app-install-alert/interfaces.js +2 -0
  35. package/dist/collection/components/salla-app-install-alert/interfaces.js.map +1 -0
  36. package/dist/collection/components/salla-app-install-alert/salla-app-install-alert.js +9 -19
  37. package/dist/collection/components/salla-app-install-alert/salla-app-install-alert.js.map +1 -1
  38. package/dist/collection/components/salla-order-summary/interfaces.js +2 -0
  39. package/dist/collection/components/salla-order-summary/interfaces.js.map +1 -0
  40. package/dist/collection/components/salla-order-summary/salla-order-summary.css +3 -0
  41. package/dist/collection/components/salla-order-summary/salla-order-summary.js +113 -0
  42. package/dist/collection/components/salla-order-summary/salla-order-summary.js.map +1 -0
  43. package/dist/collection/components/salla-order-summary/test/salla-order-summary.e2e.js +13 -0
  44. package/dist/collection/components/salla-order-summary/test/salla-order-summary.e2e.js.map +1 -0
  45. package/dist/collection/components/salla-order-summary/test/salla-order-summary.spec.js +21 -0
  46. package/dist/collection/components/salla-order-summary/test/salla-order-summary.spec.js.map +1 -0
  47. package/dist/components/salla-app-install-alert.js +9 -19
  48. package/dist/components/salla-app-install-alert.js.map +1 -1
  49. package/dist/components/salla-order-summary.d.ts +11 -0
  50. package/dist/components/salla-order-summary.js +137 -0
  51. package/dist/components/salla-order-summary.js.map +1 -0
  52. package/dist/esm/{camera-a379486d.js → camera-d0a93c12.js} +2 -9
  53. package/dist/esm/camera-d0a93c12.js.map +1 -0
  54. package/dist/esm/check-838f37a7.js +13 -0
  55. package/dist/esm/check-838f37a7.js.map +1 -0
  56. package/dist/esm/{index-e6c3f002.js → index-9a9b1e67.js} +12 -3
  57. package/dist/esm/index-9a9b1e67.js.map +1 -0
  58. package/dist/esm/loader.js +3 -3
  59. package/dist/esm/salla-add-product-button_47.entry.js +3 -2
  60. package/dist/esm/salla-add-product-button_47.entry.js.map +1 -1
  61. package/dist/esm/salla-advertisement.entry.js +1 -1
  62. package/dist/esm/salla-app-install-alert.entry.js +10 -20
  63. package/dist/esm/salla-app-install-alert.entry.js.map +1 -1
  64. package/dist/esm/salla-apps-icons.entry.js +1 -1
  65. package/dist/esm/salla-conditional-fields.entry.js +1 -1
  66. package/dist/esm/salla-contacts.entry.js +1 -1
  67. package/dist/esm/salla-filters-widget.entry.js +1 -1
  68. package/dist/esm/salla-filters.entry.js +1 -1
  69. package/dist/esm/salla-installment.entry.js +1 -1
  70. package/dist/esm/salla-loyalty-prize-item.entry.js +1 -1
  71. package/dist/esm/salla-notification-item.entry.js +1 -1
  72. package/dist/esm/salla-notifications.entry.js +1 -1
  73. package/dist/esm/salla-offer.entry.js +1 -1
  74. package/dist/esm/salla-order-summary.entry.js +103 -0
  75. package/dist/esm/salla-order-summary.entry.js.map +1 -0
  76. package/dist/esm/salla-payments.entry.js +1 -1
  77. package/dist/esm/salla-price-range.entry.js +1 -1
  78. package/dist/esm/salla-product-options.entry.js +3 -2
  79. package/dist/esm/salla-product-options.entry.js.map +1 -1
  80. package/dist/esm/salla-products-list.entry.js +1 -1
  81. package/dist/esm/salla-products-slider.entry.js +1 -1
  82. package/dist/esm/salla-social.entry.js +1 -1
  83. package/dist/esm/twilight.js +3 -3
  84. package/dist/esm-es5/camera-d0a93c12.js +5 -0
  85. package/dist/esm-es5/check-838f37a7.js +5 -0
  86. package/dist/esm-es5/{index-e6c3f002.js → index-9a9b1e67.js} +2 -2
  87. package/dist/esm-es5/index-9a9b1e67.js.map +1 -0
  88. package/dist/esm-es5/loader.js +1 -1
  89. package/dist/esm-es5/loader.js.map +1 -1
  90. package/dist/esm-es5/salla-add-product-button_47.entry.js +1 -1
  91. package/dist/esm-es5/salla-add-product-button_47.entry.js.map +1 -1
  92. package/dist/esm-es5/salla-advertisement.entry.js +1 -1
  93. package/dist/esm-es5/salla-app-install-alert.entry.js +1 -1
  94. package/dist/esm-es5/salla-app-install-alert.entry.js.map +1 -1
  95. package/dist/esm-es5/salla-apps-icons.entry.js +1 -1
  96. package/dist/esm-es5/salla-conditional-fields.entry.js +1 -1
  97. package/dist/esm-es5/salla-contacts.entry.js +1 -1
  98. package/dist/esm-es5/salla-filters-widget.entry.js +1 -1
  99. package/dist/esm-es5/salla-filters.entry.js +1 -1
  100. package/dist/esm-es5/salla-installment.entry.js +1 -1
  101. package/dist/esm-es5/salla-loyalty-prize-item.entry.js +1 -1
  102. package/dist/esm-es5/salla-notification-item.entry.js +1 -1
  103. package/dist/esm-es5/salla-notifications.entry.js +1 -1
  104. package/dist/esm-es5/salla-offer.entry.js +1 -1
  105. package/dist/esm-es5/salla-order-summary.entry.js +5 -0
  106. package/dist/esm-es5/salla-order-summary.entry.js.map +1 -0
  107. package/dist/esm-es5/salla-payments.entry.js +1 -1
  108. package/dist/esm-es5/salla-price-range.entry.js +1 -1
  109. package/dist/esm-es5/salla-product-options.entry.js +1 -1
  110. package/dist/esm-es5/salla-product-options.entry.js.map +1 -1
  111. package/dist/esm-es5/salla-products-list.entry.js +1 -1
  112. package/dist/esm-es5/salla-products-slider.entry.js +1 -1
  113. package/dist/esm-es5/salla-social.entry.js +1 -1
  114. package/dist/esm-es5/twilight.js +1 -1
  115. package/dist/esm-es5/twilight.js.map +1 -1
  116. package/dist/twilight/p-0186ffc1.js +5 -0
  117. package/dist/twilight/{p-b7b592bc.entry.js → p-06371bb0.entry.js} +2 -2
  118. package/dist/twilight/{p-3834f37c.entry.js → p-09708e69.entry.js} +2 -2
  119. package/dist/twilight/{p-06ee24b3.system.entry.js → p-0b502ded.system.entry.js} +2 -2
  120. package/dist/twilight/{p-e8d21c77.entry.js → p-1670ae9f.entry.js} +10 -10
  121. package/dist/twilight/{p-e8d21c77.entry.js.map → p-1670ae9f.entry.js.map} +1 -1
  122. package/dist/twilight/p-19338c46.entry.js +5 -0
  123. package/dist/twilight/p-19338c46.entry.js.map +1 -0
  124. package/dist/twilight/p-1d8dea0d.system.entry.js +5 -0
  125. package/dist/twilight/p-1d8dea0d.system.entry.js.map +1 -0
  126. package/dist/twilight/{p-bf4cc420.system.entry.js → p-244fdaa3.system.entry.js} +2 -2
  127. package/dist/twilight/p-26807b00.system.entry.js +5 -0
  128. package/dist/twilight/{p-3b9dc939.system.entry.js.map → p-26807b00.system.entry.js.map} +1 -1
  129. package/dist/twilight/{p-9d806602.system.entry.js → p-26ccfdb9.system.entry.js} +2 -2
  130. package/dist/twilight/{p-06d0f1fc.system.entry.js → p-27e67445.system.entry.js} +2 -2
  131. package/dist/twilight/{p-025d4f2d.system.entry.js → p-2919b445.system.entry.js} +2 -2
  132. package/dist/twilight/{p-dd9b5ccb.js → p-294dad80.js} +2 -2
  133. package/dist/twilight/p-294dad80.js.map +1 -0
  134. package/dist/twilight/{p-390ad22a.system.entry.js → p-4923a67f.system.entry.js} +2 -2
  135. package/dist/twilight/p-4f6a5307.js +5 -0
  136. package/dist/twilight/p-4f6a5307.js.map +1 -0
  137. package/dist/twilight/{p-6b22ed0e.system.entry.js → p-52e80e00.system.entry.js} +2 -2
  138. package/dist/twilight/{p-1868754d.system.entry.js → p-5ab9e320.system.entry.js} +2 -2
  139. package/dist/twilight/{p-8241fdbe.system.entry.js → p-5add79da.system.entry.js} +2 -2
  140. package/dist/twilight/{p-73543cab.entry.js → p-5cf571e0.entry.js} +2 -2
  141. package/dist/twilight/{p-ce624f5f.system.entry.js → p-5d8d9481.system.entry.js} +2 -2
  142. package/dist/twilight/p-61858adc.system.js +5 -0
  143. package/dist/twilight/p-61858adc.system.js.map +1 -0
  144. package/dist/twilight/{p-036b83ec.system.entry.js → p-63de8456.system.entry.js} +10 -10
  145. package/dist/twilight/{p-036b83ec.system.entry.js.map → p-63de8456.system.entry.js.map} +1 -1
  146. package/dist/twilight/{p-333ec93c.entry.js → p-65a4715d.entry.js} +2 -2
  147. package/dist/twilight/{p-4ce6ce88.entry.js → p-65f0067f.entry.js} +2 -2
  148. package/dist/twilight/{p-6d6256da.system.entry.js → p-66da3f43.system.entry.js} +2 -2
  149. package/dist/twilight/p-70434381.system.js +5 -0
  150. package/dist/twilight/p-70434381.system.js.map +1 -0
  151. package/dist/twilight/{p-54d6d3b2.system.entry.js → p-78b1292d.system.entry.js} +2 -2
  152. package/dist/twilight/{p-124dbc8a.entry.js → p-7ce64b51.entry.js} +2 -2
  153. package/dist/twilight/{p-c6bac58c.entry.js → p-7fc43537.entry.js} +2 -2
  154. package/dist/twilight/p-80f28677.system.js +5 -0
  155. package/dist/twilight/{p-22970c71.system.js.map → p-80f28677.system.js.map} +1 -1
  156. package/dist/twilight/{p-a576382e.entry.js → p-93a0c3f0.entry.js} +2 -2
  157. package/dist/twilight/{p-2196dcbb.entry.js → p-94ad2e62.entry.js} +2 -2
  158. package/dist/twilight/p-97a6c220.system.entry.js +5 -0
  159. package/dist/twilight/p-97a6c220.system.entry.js.map +1 -0
  160. package/dist/twilight/{p-878fc12c.system.entry.js → p-9afefe3a.system.entry.js} +2 -2
  161. package/dist/twilight/{p-2d5a5668.system.entry.js → p-bb77d0d9.system.entry.js} +2 -2
  162. package/dist/twilight/p-c7f23f03.entry.js +5 -0
  163. package/dist/twilight/{p-af0f70cd.entry.js.map → p-c7f23f03.entry.js.map} +1 -1
  164. package/dist/twilight/{p-25656ae8.entry.js → p-c8c265d7.entry.js} +2 -2
  165. package/dist/twilight/{p-9a7f3e65.system.entry.js → p-d1b7315f.system.entry.js} +2 -2
  166. package/dist/twilight/{p-041f94a6.entry.js → p-d41dfff7.entry.js} +2 -2
  167. package/dist/twilight/{p-3d58cecc.entry.js → p-d5e825e0.entry.js} +2 -2
  168. package/dist/twilight/{p-37d0c076.entry.js → p-e218f9e3.entry.js} +2 -2
  169. package/dist/twilight/{p-2768c606.entry.js → p-e6bb10f0.entry.js} +2 -2
  170. package/dist/twilight/{p-89564b2e.entry.js → p-e7aa06ff.entry.js} +2 -2
  171. package/dist/twilight/{p-a54fbc9b.system.entry.js → p-ed382e13.system.entry.js} +2 -2
  172. package/dist/twilight/{p-548cb28d.system.js → p-eebd57c0.system.js} +2 -2
  173. package/dist/twilight/p-eebd57c0.system.js.map +1 -0
  174. package/dist/twilight/{p-0c2748dd.entry.js → p-f30e7de2.entry.js} +2 -2
  175. package/dist/twilight/p-f5cd04ef.entry.js +5 -0
  176. package/dist/twilight/p-f5cd04ef.entry.js.map +1 -0
  177. package/dist/twilight/twilight.esm.js +1 -1
  178. package/dist/twilight/twilight.esm.js.map +1 -1
  179. package/dist/twilight/twilight.js +1 -1
  180. package/dist/types/components/salla-app-install-alert/interfaces.d.ts +6 -0
  181. package/dist/types/components/salla-app-install-alert/salla-app-install-alert.d.ts +5 -6
  182. package/dist/types/components/salla-order-summary/interfaces.d.ts +20 -0
  183. package/dist/types/components/salla-order-summary/salla-order-summary.d.ts +24 -0
  184. package/dist/types/components.d.ts +21 -0
  185. package/package.json +5 -5
  186. package/dist/cjs/camera-807a5122.js.map +0 -1
  187. package/dist/cjs/index-40f35e63.js.map +0 -1
  188. package/dist/esm/camera-a379486d.js.map +0 -1
  189. package/dist/esm/index-e6c3f002.js.map +0 -1
  190. package/dist/esm-es5/camera-a379486d.js +0 -5
  191. package/dist/esm-es5/index-e6c3f002.js.map +0 -1
  192. package/dist/twilight/p-22970c71.system.js +0 -5
  193. package/dist/twilight/p-3b9dc939.system.entry.js +0 -5
  194. package/dist/twilight/p-548cb28d.system.js.map +0 -1
  195. package/dist/twilight/p-59b293ab.system.entry.js +0 -5
  196. package/dist/twilight/p-59b293ab.system.entry.js.map +0 -1
  197. package/dist/twilight/p-af0f70cd.entry.js +0 -5
  198. package/dist/twilight/p-bcafcefb.system.js +0 -5
  199. package/dist/twilight/p-cbda894f.js +0 -5
  200. package/dist/twilight/p-dd9b5ccb.js.map +0 -1
  201. package/dist/twilight/p-f0a605cc.entry.js +0 -5
  202. package/dist/twilight/p-f0a605cc.entry.js.map +0 -1
  203. package/dist/types/global.d.ts +0 -20
  204. /package/dist/esm-es5/{camera-a379486d.js.map → camera-d0a93c12.js.map} +0 -0
  205. /package/dist/{twilight/p-bcafcefb.system.js.map → esm-es5/check-838f37a7.js.map} +0 -0
  206. /package/dist/twilight/{p-cbda894f.js.map → p-0186ffc1.js.map} +0 -0
  207. /package/dist/twilight/{p-b7b592bc.entry.js.map → p-06371bb0.entry.js.map} +0 -0
  208. /package/dist/twilight/{p-3834f37c.entry.js.map → p-09708e69.entry.js.map} +0 -0
  209. /package/dist/twilight/{p-06ee24b3.system.entry.js.map → p-0b502ded.system.entry.js.map} +0 -0
  210. /package/dist/twilight/{p-bf4cc420.system.entry.js.map → p-244fdaa3.system.entry.js.map} +0 -0
  211. /package/dist/twilight/{p-9d806602.system.entry.js.map → p-26ccfdb9.system.entry.js.map} +0 -0
  212. /package/dist/twilight/{p-06d0f1fc.system.entry.js.map → p-27e67445.system.entry.js.map} +0 -0
  213. /package/dist/twilight/{p-025d4f2d.system.entry.js.map → p-2919b445.system.entry.js.map} +0 -0
  214. /package/dist/twilight/{p-390ad22a.system.entry.js.map → p-4923a67f.system.entry.js.map} +0 -0
  215. /package/dist/twilight/{p-6b22ed0e.system.entry.js.map → p-52e80e00.system.entry.js.map} +0 -0
  216. /package/dist/twilight/{p-1868754d.system.entry.js.map → p-5ab9e320.system.entry.js.map} +0 -0
  217. /package/dist/twilight/{p-8241fdbe.system.entry.js.map → p-5add79da.system.entry.js.map} +0 -0
  218. /package/dist/twilight/{p-73543cab.entry.js.map → p-5cf571e0.entry.js.map} +0 -0
  219. /package/dist/twilight/{p-ce624f5f.system.entry.js.map → p-5d8d9481.system.entry.js.map} +0 -0
  220. /package/dist/twilight/{p-333ec93c.entry.js.map → p-65a4715d.entry.js.map} +0 -0
  221. /package/dist/twilight/{p-4ce6ce88.entry.js.map → p-65f0067f.entry.js.map} +0 -0
  222. /package/dist/twilight/{p-6d6256da.system.entry.js.map → p-66da3f43.system.entry.js.map} +0 -0
  223. /package/dist/twilight/{p-54d6d3b2.system.entry.js.map → p-78b1292d.system.entry.js.map} +0 -0
  224. /package/dist/twilight/{p-124dbc8a.entry.js.map → p-7ce64b51.entry.js.map} +0 -0
  225. /package/dist/twilight/{p-c6bac58c.entry.js.map → p-7fc43537.entry.js.map} +0 -0
  226. /package/dist/twilight/{p-a576382e.entry.js.map → p-93a0c3f0.entry.js.map} +0 -0
  227. /package/dist/twilight/{p-2196dcbb.entry.js.map → p-94ad2e62.entry.js.map} +0 -0
  228. /package/dist/twilight/{p-878fc12c.system.entry.js.map → p-9afefe3a.system.entry.js.map} +0 -0
  229. /package/dist/twilight/{p-2d5a5668.system.entry.js.map → p-bb77d0d9.system.entry.js.map} +0 -0
  230. /package/dist/twilight/{p-25656ae8.entry.js.map → p-c8c265d7.entry.js.map} +0 -0
  231. /package/dist/twilight/{p-9a7f3e65.system.entry.js.map → p-d1b7315f.system.entry.js.map} +0 -0
  232. /package/dist/twilight/{p-041f94a6.entry.js.map → p-d41dfff7.entry.js.map} +0 -0
  233. /package/dist/twilight/{p-3d58cecc.entry.js.map → p-d5e825e0.entry.js.map} +0 -0
  234. /package/dist/twilight/{p-37d0c076.entry.js.map → p-e218f9e3.entry.js.map} +0 -0
  235. /package/dist/twilight/{p-2768c606.entry.js.map → p-e6bb10f0.entry.js.map} +0 -0
  236. /package/dist/twilight/{p-89564b2e.entry.js.map → p-e7aa06ff.entry.js.map} +0 -0
  237. /package/dist/twilight/{p-a54fbc9b.system.entry.js.map → p-ed382e13.system.entry.js.map} +0 -0
  238. /package/dist/twilight/{p-0c2748dd.entry.js.map → p-f30e7de2.entry.js.map} +0 -0
@@ -1,5 +1,5 @@
1
1
  var __awaiter=this&&this.__awaiter||function(t,n,e,i){function o(t){return t instanceof e?t:new e((function(n){n(t)}))}return new(e||(e=Promise))((function(e,a){function r(t){try{l(i.next(t))}catch(t){a(t)}}function s(t){try{l(i["throw"](t))}catch(t){a(t)}}function l(t){t.done?e(t.value):o(t.value).then(r,s)}l((i=i.apply(t,n||[])).next())}))};var __generator=this&&this.__generator||function(t,n){var e={label:0,sent:function(){if(a[0]&1)throw a[1];return a[1]},trys:[],ops:[]},i,o,a,r;return r={next:s(0),throw:s(1),return:s(2)},typeof Symbol==="function"&&(r[Symbol.iterator]=function(){return this}),r;function s(t){return function(n){return l([t,n])}}function l(s){if(i)throw new TypeError("Generator is already executing.");while(r&&(r=0,s[0]&&(e=0)),e)try{if(i=1,o&&(a=s[0]&2?o["return"]:s[0]?o["throw"]||((a=o["return"])&&a.call(o),0):o.next)&&!(a=a.call(o,s[1])).done)return a;if(o=0,a)s=[s[0]&2,a.value];switch(s[0]){case 0:case 1:a=s;break;case 4:e.label++;return{value:s[1],done:false};case 5:e.label++;o=s[1];s=[0];continue;case 7:s=e.ops.pop();e.trys.pop();continue;default:if(!(a=e.trys,a=a.length>0&&a[a.length-1])&&(s[0]===6||s[0]===2)){e=0;continue}if(s[0]===3&&(!a||s[1]>a[0]&&s[1]<a[3])){e.label=s[1];break}if(s[0]===6&&e.label<a[1]){e.label=a[1];a=s;break}if(a&&e.label<a[2]){e.label=a[2];e.ops.push(s);break}if(a[2])e.ops.pop();e.trys.pop();continue}s=n.call(t,e)}catch(t){s=[6,t];o=0}finally{i=a=0}if(s[0]&5)throw s[1];return{value:s[0]?s[1]:void 0,done:true}}};
2
2
  /*!
3
3
  * Crafted with ❤ by Salla
4
- */import{r as registerInstance,c as createEvent,h,H as Host,g as getElement}from"./index-e6c3f002.js";import{a as CameraIcon,C as CheckCircleIcon}from"./camera-a379486d.js";var DisplayType;(function(t){t["COLOR"]="color";t["DATE"]="date";t["DATETIME"]="datetime";t["DONATION"]="donation";t["IMAGE"]="image";t["MULTIPLE_OPTIONS"]="multiple-options";t["NUMBER"]="number";t["SINGLE_OPTION"]="single-option";t["SPLITTER"]="splitter";t["TEXT"]="text";t["TEXTAREA"]="textarea";t["THUMBNAIL"]="thumbnail";t["TIME"]="time";t["RADIO"]="radio";t["CHECKBOX"]="checkbox";t["MAP"]="map";t["FILE"]="file";t["COLOR_PICKER"]="color_picker"})(DisplayType||(DisplayType={}));var Currency;(function(t){t["Sar"]="SAR"})(Currency||(Currency={}));var FileIcon='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>file-upload</title>\n<path d="M21.333 24c0.341 0 0.683-0.131 0.943-0.391 0.521-0.521 0.521-1.364 0-1.885l-5.333-5.333c-0.123-0.123-0.271-0.22-0.433-0.288-0.327-0.135-0.693-0.135-1.019 0-0.163 0.068-0.311 0.165-0.433 0.288l-5.333 5.333c-0.521 0.521-0.521 1.364 0 1.885s1.364 0.521 1.885 0l3.057-3.057v10.115c0 0.736 0.597 1.333 1.333 1.333s1.333-0.597 1.333-1.333v-10.115l3.057 3.057c0.26 0.26 0.601 0.391 0.943 0.391zM28.943 9.724l-9.333-9.333c-0.249-0.251-0.589-0.391-0.943-0.391h-12c-2.205 0-4 1.795-4 4v24c0 2.205 1.795 4 4 4h4c0.736 0 1.333-0.597 1.333-1.333s-0.597-1.333-1.333-1.333h-4c-0.735 0-1.333-0.599-1.333-1.333v-24c0-0.735 0.599-1.333 1.333-1.333h11.448l8.552 8.552v16.781c0 0.735-0.599 1.333-1.333 1.333h-4c-0.736 0-1.333 0.597-1.333 1.333s0.597 1.333 1.333 1.333h4c2.205 0 4-1.795 4-4v-17.333c0-0.353-0.14-0.693-0.391-0.943z"></path>\n</svg>\n';var sallaProductOptionsCss="";var SallaProductOptions=function(){function t(t){var n=this;registerInstance(this,t);this.changed=createEvent(this,"changed",7);this.fileTypes={pdf:"application/pdf",png:"image/png",jpg:"image/jpeg",word:"application/doc,application/ms-doc,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document",exl:"application/excel,application/vnd.ms-excel,application/x-excel,application/x-msexcel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",txt:"text/plain"};this.outSkus=[];this.handleDonationOptions=function(t,e,i){if(e=="custom"&&i=="input"){salla.helpers.inputDigitsOnly(t.target);salla.event.emit("product-options::donation-changed",{id:n.productId,price:t.target.value});return}t.preventDefault();t.stopPropagation();n.isCustomDonation=t.target.value==="custom";if(n.donationInput){if(t.target.value==="custom"){n.donationInput.value="";n.donationInput.focus()}else{n.donationInput.value=t.target.value}if(e=="custom"){return}salla.event.emit("product-options::donation-changed",{id:n.productId,price:t.target.value})}};this.hideLabel=function(t){if(t.type===DisplayType.DONATION&&(t.donation&&!t.donation.can_donate)){return true}return false};this.getExpireDonationMessage=function(t){if(!t.donation){return}var n=t.donation.target_amount<=t.donation.collected_amount;return h("div",{class:{"s-product-options-donation-message":true,"s-product-options-donation-completed":n,"s-product-options-donation-expired":!n}},h("p",null,t.donation.target_message),h("span",null,n?salla.money(t.donation.target_amount):""))};this.optionsData=undefined;this.outOfStockText="";this.donationAmount=salla.lang.get("pages.products.donation_amount");this.selectDonationAmount=salla.lang.getWithDefault("pages.products.select_donation_amount","تحديد مبلغ التبرع");this.selectAmount=salla.lang.getWithDefault("pages.products.select_amount","اختر المبلغ");this.isCustomDonation=false;this.selectedOptions=[];this.canDisabled=undefined;this.selectedSkus=undefined;this.selectedOutSkus=undefined;this.productId=salla.config.get("page.id");this.options=undefined;this.canDisabled=!salla.config.get("store.settings.product.notify_options_availability");salla.lang.onLoaded((function(){n.outOfStockText=salla.lang.get("pages.products.out_of_stock");n.donationAmount=salla.lang.get("pages.products.donation_amount");n.selectDonationAmount=salla.lang.getWithDefault("pages.products.select_donation_amount","تحديد مبلغ التبرع");n.selectAmount=salla.lang.getWithDefault("pages.products.select_amount","اختر المبلغ")}));if(this.options){try{this.setOptionsData(Array.isArray(this.options)?this.options:JSON.parse(this.options));return}catch(t){salla.log("Bad json passed via options prop")}}if(!Array.isArray(this.optionsData)){salla.log("Options is not an array[] ---\x3e ",this.optionsData);this.setOptionsData([])}if(this.productId&&!salla.url.is_page("cart")){salla.api.product.getDetails(this.productId,["options"]).then((function(t){return n.setOptionsData(t.data.options)}))}}t.prototype.setOptionsData=function(t){var n,e;this.optionsData=t;var i=this;(e=(n=this.optionsData[0])===null||n===void 0?void 0:n.details)===null||e===void 0?void 0:e.forEach((function(t){Object.entries(t.skus_availability||{}).filter((function(t){return!t[1]})).map((function(t){return i.outSkus.push(Number(t[0]))}))}))};t.prototype.getSelectedOptionsData=function(){return __awaiter(this,void 0,void 0,(function(){var t,n;return __generator(this,(function(e){t={};n=this.host.getElementSallaData();n.forEach((function(n,e){e.startsWith("options[")&&(t[e.replace("options[","").replace("]","")]=n)}));return[2,t]}))}))};t.prototype.reportValidity=function(){return __awaiter(this,void 0,void 0,(function(){var t,n,e;return __generator(this,(function(i){t=this.host.querySelectorAll("[required]");n=true;for(e=0;e<t.length;e++){if("reportValidity"in t[e]&&!t[e].reportValidity()){n=false}}return[2,n]}))}))};t.prototype.hasOutOfStockOption=function(){return __awaiter(this,void 0,void 0,(function(){var t,n;var e=this;return __generator(this,(function(i){return[2,this.selectedOptions.some((function(t){return t.is_out}))||((t=this.selectedSkus)===null||t===void 0?void 0:t.length)&&((n=this.selectedSkus)===null||n===void 0?void 0:n.every((function(t){return e.outSkus.includes(t)})))]}))}))};t.prototype.getSelectedOptions=function(){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(t){return[2,this.selectedOptions]}))}))};t.prototype.getOption=function(t){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(n){return[2,this.optionsData.find((function(n){return n.id===t}))]}))}))};t.prototype.invalidHandler=function(t,n){var e=t.target.closest(".s-product-options-option");if(!salla.url.is_page("cart")){e.scrollIntoView({behavior:"smooth",block:"center"})}e.classList.add("s-product-options-option-error")};t.prototype.changedHandler=function(t,n){var e={event:t,option:n,detail:null};if(n.details){var i=n.details.find((function(n){return Number(n.id)===Number(t.target.value)}));e.detail=i}var o=t.target.closest(".s-product-options-option");if(t.target.value||(n.type==DisplayType.FILE||n.type==DisplayType.IMAGE)&&t.type==="added"||n.type==DisplayType.MAP&&t.type==="selected"&&(t.target.lat&&t.target.lng)){setTimeout((function(){o.classList.remove("s-product-options-option-error")}),200)}var a=this.selectedOptions.findIndex((function(t){return t.option_id===e.option.id}));a>-1?this.selectedOptions[a]=Object.assign(Object.assign({},e.detail),{option_id:e.option.id}):this.selectedOptions.push(Object.assign(Object.assign({},e.detail),{option_id:e.option.id}));if(n.type==DisplayType.DONATION){salla.event.emit("product-options::donation-changed",{id:this.productId,price:t.target.value})}this.setSelectedSkus();this.handleRequiredMultipleOptions(n);this.changed.emit(e);salla.event.emit("product-options::change",e)};t.prototype.setSelectedSkus=function(){this.selectedSkus=this.selectedOptions.map((function(t){return Object.keys(t.skus_availability||{})})).reduce((function(t,n){return t.filter((function(t){return n.includes(t)}))})).map((function(t){return Number(t)}))};t.prototype.handleRequiredMultipleOptions=function(t){if(t.type!==DisplayType.MULTIPLE_OPTIONS||!t.required){return}var n=this.host.querySelector('[data-option-id="'.concat(t.id,'"]'));var e=n.querySelectorAll("input:checked").length;n.querySelectorAll("input").forEach((function(t){return t.toggleAttribute("required",!e)}))};t.prototype.getLatLng=function(t,n){return t?t.split(",")[n=="lat"?0:1]:""};t.prototype.getDisplayForType=function(t){if(this["".concat(t.type,"Option")]){return this["".concat(t.type,"Option")](t)}if(t.type===DisplayType.COLOR_PICKER){return this.colorPickerOption(t)}if(t.type===DisplayType.MULTIPLE_OPTIONS){return this.multipleOptions(t)}if(t.type===DisplayType.SINGLE_OPTION){return this.singleOption(t)}salla.log("Couldn't find options type(".concat(t.type,")😢"));return""};t.prototype.getOptionShownWhen=function(t){return t.visibility_condition?{"data-show-when":"options[".concat(t.visibility_condition.option,"] ").concat(t.visibility_condition.operator," ").concat(t.visibility_condition.value)}:{}};t.prototype.componentWillLoad=function(){this.outOfStockText=salla.lang.get("pages.products.out_of_stock");return salla.api.cart.getCurrentCartId()};t.prototype.componentDidRender=function(){var t=this;var n,e;if(((n=this.optionsData)===null||n===void 0?void 0:n.length)==0&&!this.optionsData.some((function(t){return t.type==DisplayType.DONATION}))){return}var i=(e=this.optionsData.find((function(t){return t.type==DisplayType.DONATION})))===null||e===void 0?void 0:e.details.find((function(t){return t.is_selected}));if(!i){return}setTimeout((function(){salla.event.emit("product-options::donation-changed",{id:t.productId,price:i.additional_price})}),1e3)};t.prototype.render=function(){var t=this;var n;if(((n=this.optionsData)===null||n===void 0?void 0:n.length)==0){return}return h(Host,{class:"s-product-options-wrapper"},h("salla-conditional-fields",null,this.optionsData.map((function(n){return h("div",Object.assign({class:"s-product-options-option-container".concat(n.visibility_condition?" hidden":""),"data-option-id":n.id},t.getOptionShownWhen(n)),n.name=="splitter"?t.splitterOption():h("div",{class:"s-product-options-option","data-option-type":n.type,"data-option-required":"".concat(n.required)},h("label",{htmlFor:"options["+n.id+"]",class:"s-product-options-option-label ".concat(t.hideLabel(n)?"s-product-options-option-label-hidden":"")},h("b",null,n.name,n.required&&h("span",null," * ")," "),h("small",null,n.placeholder)),h("div",{class:"s-product-options-option-content ".concat(t.hideLabel(n)?"s-product-options-option-content-full-width":"")},t.getDisplayForType(n))))}))))};t.prototype.donationOption=function(t,n){var e=this;var i,o;return h("div",{class:"s-product-options-donation-wrapper"},((i=t.donation)===null||i===void 0?void 0:i.can_donate)?[t.donation?h("div",{class:"s-product-options-donation-progress"},h("salla-progress-bar",{donation:t.donation})):"",t.details.length?[h("h4",null,this.selectAmount),h("div",{class:"s-product-options-donation-options"},t.details.map((function(t,n){return h("div",{class:"s-product-options-donation-options-item"},h("input",{id:"donation-option-".concat(n),type:"radio",name:"donating_option",checked:t.is_selected,value:t.additional_price,onChange:function(n){return e.handleDonationOptions(n,t,"option")}}),h("label",{htmlFor:"donation-option-".concat(n)},h("span",null,salla.money(t.name))))})),((o=t.donation)===null||o===void 0?void 0:o.custom_amount_enabled)?h("div",{class:"s-product-options-donation-options-item"},h("input",{id:"donation-option-custom",type:"radio",name:"donating_option",value:"custom",onChange:function(t){return e.handleDonationOptions(t,"custom","option")}}),h("label",{htmlFor:"donation-option-custom"},h("span",null," ",this.selectDonationAmount," "))):"")]:"",h("div",{class:{"s-product-options-donation-input-group":true,shown:!t.details.length||t.details.length&&this.isCustomDonation}},h("input",{type:"text",id:"donating-amount",name:"donation_amount",class:"s-form-control",ref:function(t){return e.donationInput=t},value:t.details.length&&t.details.some((function(t){return t.is_selected}))?t.details.find((function(t){return t.is_selected})).additional_price:t.value,placeholder:t.placeholder,onInput:function(t){return e.handleDonationOptions(t,"custom","input")},onBlur:function(n){return e.changedHandler(n,t)},onInvalid:function(n){return e.invalidHandler(n,t)}}),h("span",{class:"s-product-options-donation-amount-currency"},salla.config.currency(salla.config.get("user.currency_code")).symbol))]:this.getExpireDonationMessage(t))};t.prototype.fileUploader=function(t,n){var e=this;if(n===void 0){n=null}return h("salla-file-upload",Object.assign({},n||{},{"payload-name":"file",value:t.value,"instant-upload":true,name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,height:"120px",onAdded:function(n){return e.changedHandler(n,t)},url:salla.cart.api.getUploadImageEndpoint(),"form-data":{cart_item_id:this.productId,product_id:this.productId},onInvalidInput:function(n){return e.invalidHandler(n,t)},class:{"s-product-options-image-input":true,required:t.required}}),h("div",{class:"s-product-options-filepond-placeholder"},h("span",{class:"s-product-options-filepond-placeholder-icon",innerHTML:n.accept&&n.accept.split(",").every((function(t){return t.includes("image")}))?CameraIcon:FileIcon}),h("p",{class:"s-product-options-filepond-placeholder-text"},salla.lang.get("common.uploader.drag_and_drop")),h("span",{class:"filepond--label-action"},salla.lang.get("common.uploader.browse"))))};t.prototype.imageOption=function(t){return this.fileUploader(t,{accept:"image/png,image/jpeg,image/jpg,image/gif"})};t.prototype.fileOption=function(t){var n=this;var e=t.details.map((function(t){return n.fileTypes[t.name]})).filter(Boolean);return(e===null||e===void 0?void 0:e.length)?this.fileUploader(t,{accept:e.join(",")}):"File types not selected."};t.prototype.numberOption=function(t){var n=this;return h("input",{type:"text",value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onBlur:function(e){return n.changedHandler(e,t)},onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(t){return salla.helpers.inputDigitsOnly(t.target)}})};t.prototype.splitterOption=function(){return h("div",{class:"s-product-options-splitter"})};t.prototype.textOption=function(t){var n=this;return h("div",{class:"s-product-options-text"},h("input",{type:"text",value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(e){return n.changedHandler(e,t)}}))};t.prototype.textareaOption=function(t){var n=this;return h("div",{class:"s-product-options-textarea"},h("div",{class:"mt-1"},h("textarea",{rows:4,value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,id:"options[".concat(t.id,"]"),name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(e){return n.changedHandler(e,t)}})))};t.prototype.mapOption=function(t){var n=this;return h("salla-map",{zoom:15,lat:this.getLatLng(t.value,"lat"),lng:this.getLatLng(t.value,"lng"),name:"options[".concat(t.id,"]"),searchable:true,required:t.required,onInvalidInput:function(e){return n.invalidHandler(e,t)},onSelected:function(e){return n.changedHandler(e,t)}})};t.prototype.colorPickerOption=function(t){var n=this;return h("salla-color-picker",{onSubmitted:function(e){return n.changedHandler(e,t)},name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,onInvalidInput:function(e){return n.invalidHandler(e,t)},color:t.value})};t.prototype.timeOption=function(t){var n=this;return h("salla-datetime-picker",{noCalendar:true,enableTime:true,dateFormat:"h:i K",value:t.value,placeholder:t.name,required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),class:"s-product-options-time-element",onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}})};t.prototype.dateOption=function(t){var n=this;return h("div",{class:"s-product-options-date-element"},h("salla-datetime-picker",{value:t.value,placeholder:t.name,required:!t.visibility_condition&&t.required,minDate:new Date,name:"options[".concat(t.id,"]"),onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}}))};t.prototype.datetimeOption=function(t){var n=this;return h("div",{class:"s-product-options-datetime-element"},h("salla-datetime-picker",{enableTime:true,value:t.value,dateFormat:"Y-m-d G:i:K",placeholder:t.name,required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),maxDate:t.to_date_time,minDate:t.from_date_time,onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}}))};t.prototype.getOptionDetailName=function(t,n,e){if(n===void 0){n=true}if(e&&e==DisplayType.COLOR){return t.name+(n&&this.isOptionDetailOut(t)?" <br/> <p> ".concat(this.outOfStockText," </p>"):"")+(t.additional_price?" <p> (".concat(salla.money(t.additional_price),") </p>"):"")}return t.name+(n&&this.isOptionDetailOut(t)?" - ".concat(this.outOfStockText):"")+(t.additional_price?" (".concat(salla.money(t.additional_price),")"):"")};t.prototype.isOptionDetailOut=function(t){var n=this;var e;if(t.is_out||!t.skus_availability||!((e=this.selectedSkus)===null||e===void 0?void 0:e.length)){return t.is_out}var i=this.selectedOptions.filter((function(n){return n.id==t.id})).length;if(i&&this.selectedOptions.length==1){return false}if(i){var o=this.selectedSkus.filter((function(t){return n.outSkus.includes(t)}));return Object.keys(t.skus_availability).some((function(t){return o.includes(Number(t))}))}return this.selectedOptions.some((function(n){return n.is_out&&n.option_id!==t.option_id}))};t.prototype.singleOption=function(t){var n=this;return h("div",null,h("select",{name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,class:"s-form-control",onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}},h("option",{value:""},t.placeholder),t===null||t===void 0?void 0:t.details.map((function(t){return h("option",{value:t.id,disabled:n.canDisabled&&n.isOptionDetailOut(t),selected:t.is_selected},n.getOptionDetailName(t))}))))};t.prototype.multipleOptions=function(t){var n=this;var e=t.required&&!t.details.some((function(t){return t.is_selected}))&&!t.visibility_condition;return h("div",{class:{"s-product-options-multiple-options-wrapper":true,required:t.required}},t===null||t===void 0?void 0:t.details.map((function(i){return h("div",null,h("input",{type:"checkbox",value:i.id,disabled:n.isOptionDetailOut(i),checked:i.is_selected,required:e,name:"options[".concat(t.id,"][]"),id:"field-".concat(t.id,"-").concat(i.id),onChange:function(e){return n.changedHandler(e,t)},onInvalid:function(e){return n.invalidHandler(e,t)},"aria-describedby":"options[".concat(t.id,"]-description")}),h("label",{htmlFor:"field-".concat(t.id,"-").concat(i.id)},n.getOptionDetailName(i)))})))};t.prototype.colorOption=function(t){var n=this;return h("fieldset",{class:"s-product-options-colors-wrapper"},t===null||t===void 0?void 0:t.details.map((function(e){return h("div",{class:"s-product-options-colors-item"},h("input",{type:"radio",value:e.id,required:!t.visibility_condition&&t.required,checked:e.is_selected,name:"options[".concat(t.id,"]"),disabled:n.canDisabled&&n.isOptionDetailOut(e),id:"color-".concat(n.productId,"-").concat(t.id,"-").concat(e.id),onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}}),h("label",{htmlFor:"color-".concat(n.productId,"-").concat(t.id,"-").concat(e.id)},h("span",{style:{"background-color":e.color}}),h("div",{innerHTML:n.getOptionDetailName(e,true,t.type)})))})))};t.prototype.thumbnailOption=function(t){var n=this;return h("div",{class:"s-product-options-thumbnails-wrapper"},t.details.map((function(e){return h("div",null,h("input",{type:"radio",value:e.id,"data-itemid":e.id,required:!t.visibility_condition&&t.required,checked:e.is_selected,name:"options[".concat(t.id,"]"),"data-img-id":e.option_value,disabled:n.canDisabled&&n.isOptionDetailOut(e),id:"option_".concat(n.productId,"-").concat(t.id,"_").concat(e.id),onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}}),h("label",{htmlFor:"option_".concat(n.productId,"-").concat(t.id,"_").concat(e.id),"data-img-id":e.option_value,class:"go-to-slide"},h("img",{"data-src":e.image,src:e.image,title:e.name,alt:e.name}),h("span",{innerHTML:CheckCircleIcon,class:"s-product-options-thumbnails-icon"}),n.isOptionDetailOut(e)?[h("small",{class:"s-product-options-thumbnails-stock-badge"},n.outOfStockText),n.canDisabled?h("div",{class:"s-product-options-thumbnails-badge-overlay"}):""]:""),h("p",null,n.getOptionDetailName(e,false)," "))})))};Object.defineProperty(t.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return t}();SallaProductOptions.style=sallaProductOptionsCss;export{SallaProductOptions as salla_product_options};
4
+ */import{r as registerInstance,c as createEvent,h,H as Host,g as getElement}from"./index-9a9b1e67.js";import{C as CheckCircleIcon}from"./check-838f37a7.js";import{C as CameraIcon}from"./camera-d0a93c12.js";var DisplayType;(function(t){t["COLOR"]="color";t["DATE"]="date";t["DATETIME"]="datetime";t["DONATION"]="donation";t["IMAGE"]="image";t["MULTIPLE_OPTIONS"]="multiple-options";t["NUMBER"]="number";t["SINGLE_OPTION"]="single-option";t["SPLITTER"]="splitter";t["TEXT"]="text";t["TEXTAREA"]="textarea";t["THUMBNAIL"]="thumbnail";t["TIME"]="time";t["RADIO"]="radio";t["CHECKBOX"]="checkbox";t["MAP"]="map";t["FILE"]="file";t["COLOR_PICKER"]="color_picker"})(DisplayType||(DisplayType={}));var Currency;(function(t){t["Sar"]="SAR"})(Currency||(Currency={}));var FileIcon='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>file-upload</title>\n<path d="M21.333 24c0.341 0 0.683-0.131 0.943-0.391 0.521-0.521 0.521-1.364 0-1.885l-5.333-5.333c-0.123-0.123-0.271-0.22-0.433-0.288-0.327-0.135-0.693-0.135-1.019 0-0.163 0.068-0.311 0.165-0.433 0.288l-5.333 5.333c-0.521 0.521-0.521 1.364 0 1.885s1.364 0.521 1.885 0l3.057-3.057v10.115c0 0.736 0.597 1.333 1.333 1.333s1.333-0.597 1.333-1.333v-10.115l3.057 3.057c0.26 0.26 0.601 0.391 0.943 0.391zM28.943 9.724l-9.333-9.333c-0.249-0.251-0.589-0.391-0.943-0.391h-12c-2.205 0-4 1.795-4 4v24c0 2.205 1.795 4 4 4h4c0.736 0 1.333-0.597 1.333-1.333s-0.597-1.333-1.333-1.333h-4c-0.735 0-1.333-0.599-1.333-1.333v-24c0-0.735 0.599-1.333 1.333-1.333h11.448l8.552 8.552v16.781c0 0.735-0.599 1.333-1.333 1.333h-4c-0.736 0-1.333 0.597-1.333 1.333s0.597 1.333 1.333 1.333h4c2.205 0 4-1.795 4-4v-17.333c0-0.353-0.14-0.693-0.391-0.943z"></path>\n</svg>\n';var sallaProductOptionsCss="";var SallaProductOptions=function(){function t(t){var n=this;registerInstance(this,t);this.changed=createEvent(this,"changed",7);this.fileTypes={pdf:"application/pdf",png:"image/png",jpg:"image/jpeg",word:"application/doc,application/ms-doc,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document",exl:"application/excel,application/vnd.ms-excel,application/x-excel,application/x-msexcel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",txt:"text/plain"};this.outSkus=[];this.handleDonationOptions=function(t,e,i){if(e=="custom"&&i=="input"){salla.helpers.inputDigitsOnly(t.target);salla.event.emit("product-options::donation-changed",{id:n.productId,price:t.target.value});return}t.preventDefault();t.stopPropagation();n.isCustomDonation=t.target.value==="custom";if(n.donationInput){if(t.target.value==="custom"){n.donationInput.value="";n.donationInput.focus()}else{n.donationInput.value=t.target.value}if(e=="custom"){return}salla.event.emit("product-options::donation-changed",{id:n.productId,price:t.target.value})}};this.hideLabel=function(t){if(t.type===DisplayType.DONATION&&(t.donation&&!t.donation.can_donate)){return true}return false};this.getExpireDonationMessage=function(t){if(!t.donation){return}var n=t.donation.target_amount<=t.donation.collected_amount;return h("div",{class:{"s-product-options-donation-message":true,"s-product-options-donation-completed":n,"s-product-options-donation-expired":!n}},h("p",null,t.donation.target_message),h("span",null,n?salla.money(t.donation.target_amount):""))};this.optionsData=undefined;this.outOfStockText="";this.donationAmount=salla.lang.get("pages.products.donation_amount");this.selectDonationAmount=salla.lang.getWithDefault("pages.products.select_donation_amount","تحديد مبلغ التبرع");this.selectAmount=salla.lang.getWithDefault("pages.products.select_amount","اختر المبلغ");this.isCustomDonation=false;this.selectedOptions=[];this.canDisabled=undefined;this.selectedSkus=undefined;this.selectedOutSkus=undefined;this.productId=salla.config.get("page.id");this.options=undefined;this.canDisabled=!salla.config.get("store.settings.product.notify_options_availability");salla.lang.onLoaded((function(){n.outOfStockText=salla.lang.get("pages.products.out_of_stock");n.donationAmount=salla.lang.get("pages.products.donation_amount");n.selectDonationAmount=salla.lang.getWithDefault("pages.products.select_donation_amount","تحديد مبلغ التبرع");n.selectAmount=salla.lang.getWithDefault("pages.products.select_amount","اختر المبلغ")}));if(this.options){try{this.setOptionsData(Array.isArray(this.options)?this.options:JSON.parse(this.options));return}catch(t){salla.log("Bad json passed via options prop")}}if(!Array.isArray(this.optionsData)){salla.log("Options is not an array[] ---\x3e ",this.optionsData);this.setOptionsData([])}if(this.productId&&!salla.url.is_page("cart")){salla.api.product.getDetails(this.productId,["options"]).then((function(t){return n.setOptionsData(t.data.options)}))}}t.prototype.setOptionsData=function(t){var n,e;this.optionsData=t;var i=this;(e=(n=this.optionsData[0])===null||n===void 0?void 0:n.details)===null||e===void 0?void 0:e.forEach((function(t){Object.entries(t.skus_availability||{}).filter((function(t){return!t[1]})).map((function(t){return i.outSkus.push(Number(t[0]))}))}))};t.prototype.getSelectedOptionsData=function(){return __awaiter(this,void 0,void 0,(function(){var t,n;return __generator(this,(function(e){t={};n=this.host.getElementSallaData();n.forEach((function(n,e){e.startsWith("options[")&&(t[e.replace("options[","").replace("]","")]=n)}));return[2,t]}))}))};t.prototype.reportValidity=function(){return __awaiter(this,void 0,void 0,(function(){var t,n,e;return __generator(this,(function(i){t=this.host.querySelectorAll("[required]");n=true;for(e=0;e<t.length;e++){if("reportValidity"in t[e]&&!t[e].reportValidity()){n=false}}return[2,n]}))}))};t.prototype.hasOutOfStockOption=function(){return __awaiter(this,void 0,void 0,(function(){var t,n;var e=this;return __generator(this,(function(i){return[2,this.selectedOptions.some((function(t){return t.is_out}))||((t=this.selectedSkus)===null||t===void 0?void 0:t.length)&&((n=this.selectedSkus)===null||n===void 0?void 0:n.every((function(t){return e.outSkus.includes(t)})))]}))}))};t.prototype.getSelectedOptions=function(){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(t){return[2,this.selectedOptions]}))}))};t.prototype.getOption=function(t){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(n){return[2,this.optionsData.find((function(n){return n.id===t}))]}))}))};t.prototype.invalidHandler=function(t,n){var e=t.target.closest(".s-product-options-option");if(!salla.url.is_page("cart")){e.scrollIntoView({behavior:"smooth",block:"center"})}e.classList.add("s-product-options-option-error")};t.prototype.changedHandler=function(t,n){var e={event:t,option:n,detail:null};if(n.details){var i=n.details.find((function(n){return Number(n.id)===Number(t.target.value)}));e.detail=i}var o=t.target.closest(".s-product-options-option");if(t.target.value||(n.type==DisplayType.FILE||n.type==DisplayType.IMAGE)&&t.type==="added"||n.type==DisplayType.MAP&&t.type==="selected"&&(t.target.lat&&t.target.lng)){setTimeout((function(){o.classList.remove("s-product-options-option-error")}),200)}var a=this.selectedOptions.findIndex((function(t){return t.option_id===e.option.id}));a>-1?this.selectedOptions[a]=Object.assign(Object.assign({},e.detail),{option_id:e.option.id}):this.selectedOptions.push(Object.assign(Object.assign({},e.detail),{option_id:e.option.id}));if(n.type==DisplayType.DONATION){salla.event.emit("product-options::donation-changed",{id:this.productId,price:t.target.value})}this.setSelectedSkus();this.handleRequiredMultipleOptions(n);this.changed.emit(e);salla.event.emit("product-options::change",e)};t.prototype.setSelectedSkus=function(){this.selectedSkus=this.selectedOptions.map((function(t){return Object.keys(t.skus_availability||{})})).reduce((function(t,n){return t.filter((function(t){return n.includes(t)}))})).map((function(t){return Number(t)}))};t.prototype.handleRequiredMultipleOptions=function(t){if(t.type!==DisplayType.MULTIPLE_OPTIONS||!t.required){return}var n=this.host.querySelector('[data-option-id="'.concat(t.id,'"]'));var e=n.querySelectorAll("input:checked").length;n.querySelectorAll("input").forEach((function(t){return t.toggleAttribute("required",!e)}))};t.prototype.getLatLng=function(t,n){return t?t.split(",")[n=="lat"?0:1]:""};t.prototype.getDisplayForType=function(t){if(this["".concat(t.type,"Option")]){return this["".concat(t.type,"Option")](t)}if(t.type===DisplayType.COLOR_PICKER){return this.colorPickerOption(t)}if(t.type===DisplayType.MULTIPLE_OPTIONS){return this.multipleOptions(t)}if(t.type===DisplayType.SINGLE_OPTION){return this.singleOption(t)}salla.log("Couldn't find options type(".concat(t.type,")😢"));return""};t.prototype.getOptionShownWhen=function(t){return t.visibility_condition?{"data-show-when":"options[".concat(t.visibility_condition.option,"] ").concat(t.visibility_condition.operator," ").concat(t.visibility_condition.value)}:{}};t.prototype.componentWillLoad=function(){this.outOfStockText=salla.lang.get("pages.products.out_of_stock");return salla.api.cart.getCurrentCartId()};t.prototype.componentDidRender=function(){var t=this;var n,e;if(((n=this.optionsData)===null||n===void 0?void 0:n.length)==0&&!this.optionsData.some((function(t){return t.type==DisplayType.DONATION}))){return}var i=(e=this.optionsData.find((function(t){return t.type==DisplayType.DONATION})))===null||e===void 0?void 0:e.details.find((function(t){return t.is_selected}));if(!i){return}setTimeout((function(){salla.event.emit("product-options::donation-changed",{id:t.productId,price:i.additional_price})}),1e3)};t.prototype.render=function(){var t=this;var n;if(((n=this.optionsData)===null||n===void 0?void 0:n.length)==0){return}return h(Host,{class:"s-product-options-wrapper"},h("salla-conditional-fields",null,this.optionsData.map((function(n){return h("div",Object.assign({class:"s-product-options-option-container".concat(n.visibility_condition?" hidden":""),"data-option-id":n.id},t.getOptionShownWhen(n)),n.name=="splitter"?t.splitterOption():h("div",{class:"s-product-options-option","data-option-type":n.type,"data-option-required":"".concat(n.required)},h("label",{htmlFor:"options["+n.id+"]",class:"s-product-options-option-label ".concat(t.hideLabel(n)?"s-product-options-option-label-hidden":"")},h("b",null,n.name,n.required&&h("span",null," * ")," "),h("small",null,n.placeholder)),h("div",{class:"s-product-options-option-content ".concat(t.hideLabel(n)?"s-product-options-option-content-full-width":"")},t.getDisplayForType(n))))}))))};t.prototype.donationOption=function(t,n){var e=this;var i,o;return h("div",{class:"s-product-options-donation-wrapper"},((i=t.donation)===null||i===void 0?void 0:i.can_donate)?[t.donation?h("div",{class:"s-product-options-donation-progress"},h("salla-progress-bar",{donation:t.donation})):"",t.details.length?[h("h4",null,this.selectAmount),h("div",{class:"s-product-options-donation-options"},t.details.map((function(t,n){return h("div",{class:"s-product-options-donation-options-item"},h("input",{id:"donation-option-".concat(n),type:"radio",name:"donating_option",checked:t.is_selected,value:t.additional_price,onChange:function(n){return e.handleDonationOptions(n,t,"option")}}),h("label",{htmlFor:"donation-option-".concat(n)},h("span",null,salla.money(t.name))))})),((o=t.donation)===null||o===void 0?void 0:o.custom_amount_enabled)?h("div",{class:"s-product-options-donation-options-item"},h("input",{id:"donation-option-custom",type:"radio",name:"donating_option",value:"custom",onChange:function(t){return e.handleDonationOptions(t,"custom","option")}}),h("label",{htmlFor:"donation-option-custom"},h("span",null," ",this.selectDonationAmount," "))):"")]:"",h("div",{class:{"s-product-options-donation-input-group":true,shown:!t.details.length||t.details.length&&this.isCustomDonation}},h("input",{type:"text",id:"donating-amount",name:"donation_amount",class:"s-form-control",ref:function(t){return e.donationInput=t},value:t.details.length&&t.details.some((function(t){return t.is_selected}))?t.details.find((function(t){return t.is_selected})).additional_price:t.value,placeholder:t.placeholder,onInput:function(t){return e.handleDonationOptions(t,"custom","input")},onBlur:function(n){return e.changedHandler(n,t)},onInvalid:function(n){return e.invalidHandler(n,t)}}),h("span",{class:"s-product-options-donation-amount-currency"},salla.config.currency(salla.config.get("user.currency_code")).symbol))]:this.getExpireDonationMessage(t))};t.prototype.fileUploader=function(t,n){var e=this;if(n===void 0){n=null}return h("salla-file-upload",Object.assign({},n||{},{"payload-name":"file",value:t.value,"instant-upload":true,name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,height:"120px",onAdded:function(n){return e.changedHandler(n,t)},url:salla.cart.api.getUploadImageEndpoint(),"form-data":{cart_item_id:this.productId,product_id:this.productId},onInvalidInput:function(n){return e.invalidHandler(n,t)},class:{"s-product-options-image-input":true,required:t.required}}),h("div",{class:"s-product-options-filepond-placeholder"},h("span",{class:"s-product-options-filepond-placeholder-icon",innerHTML:n.accept&&n.accept.split(",").every((function(t){return t.includes("image")}))?CameraIcon:FileIcon}),h("p",{class:"s-product-options-filepond-placeholder-text"},salla.lang.get("common.uploader.drag_and_drop")),h("span",{class:"filepond--label-action"},salla.lang.get("common.uploader.browse"))))};t.prototype.imageOption=function(t){return this.fileUploader(t,{accept:"image/png,image/jpeg,image/jpg,image/gif"})};t.prototype.fileOption=function(t){var n=this;var e=t.details.map((function(t){return n.fileTypes[t.name]})).filter(Boolean);return(e===null||e===void 0?void 0:e.length)?this.fileUploader(t,{accept:e.join(",")}):"File types not selected."};t.prototype.numberOption=function(t){var n=this;return h("input",{type:"text",value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onBlur:function(e){return n.changedHandler(e,t)},onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(t){return salla.helpers.inputDigitsOnly(t.target)}})};t.prototype.splitterOption=function(){return h("div",{class:"s-product-options-splitter"})};t.prototype.textOption=function(t){var n=this;return h("div",{class:"s-product-options-text"},h("input",{type:"text",value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(e){return n.changedHandler(e,t)}}))};t.prototype.textareaOption=function(t){var n=this;return h("div",{class:"s-product-options-textarea"},h("div",{class:"mt-1"},h("textarea",{rows:4,value:t.value,class:"s-form-control",required:!t.visibility_condition&&t.required,id:"options[".concat(t.id,"]"),name:"options[".concat(t.id,"]"),placeholder:t.placeholder,onInvalid:function(e){return n.invalidHandler(e,t)},onInput:function(e){return n.changedHandler(e,t)}})))};t.prototype.mapOption=function(t){var n=this;return h("salla-map",{zoom:15,lat:this.getLatLng(t.value,"lat"),lng:this.getLatLng(t.value,"lng"),name:"options[".concat(t.id,"]"),searchable:true,required:t.required,onInvalidInput:function(e){return n.invalidHandler(e,t)},onSelected:function(e){return n.changedHandler(e,t)}})};t.prototype.colorPickerOption=function(t){var n=this;return h("salla-color-picker",{onSubmitted:function(e){return n.changedHandler(e,t)},name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,onInvalidInput:function(e){return n.invalidHandler(e,t)},color:t.value})};t.prototype.timeOption=function(t){var n=this;return h("salla-datetime-picker",{noCalendar:true,enableTime:true,dateFormat:"h:i K",value:t.value,placeholder:t.name,required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),class:"s-product-options-time-element",onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}})};t.prototype.dateOption=function(t){var n=this;return h("div",{class:"s-product-options-date-element"},h("salla-datetime-picker",{value:t.value,placeholder:t.name,required:!t.visibility_condition&&t.required,minDate:new Date,name:"options[".concat(t.id,"]"),onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}}))};t.prototype.datetimeOption=function(t){var n=this;return h("div",{class:"s-product-options-datetime-element"},h("salla-datetime-picker",{enableTime:true,value:t.value,dateFormat:"Y-m-d G:i:K",placeholder:t.name,required:!t.visibility_condition&&t.required,name:"options[".concat(t.id,"]"),maxDate:t.to_date_time,minDate:t.from_date_time,onInvalidInput:function(e){return n.invalidHandler(e,t)},onPicked:function(e){return n.changedHandler(e,t)}}))};t.prototype.getOptionDetailName=function(t,n,e){if(n===void 0){n=true}if(e&&e==DisplayType.COLOR){return t.name+(n&&this.isOptionDetailOut(t)?" <br/> <p> ".concat(this.outOfStockText," </p>"):"")+(t.additional_price?" <p> (".concat(salla.money(t.additional_price),") </p>"):"")}return t.name+(n&&this.isOptionDetailOut(t)?" - ".concat(this.outOfStockText):"")+(t.additional_price?" (".concat(salla.money(t.additional_price),")"):"")};t.prototype.isOptionDetailOut=function(t){var n=this;var e;if(t.is_out||!t.skus_availability||!((e=this.selectedSkus)===null||e===void 0?void 0:e.length)){return t.is_out}var i=this.selectedOptions.filter((function(n){return n.id==t.id})).length;if(i&&this.selectedOptions.length==1){return false}if(i){var o=this.selectedSkus.filter((function(t){return n.outSkus.includes(t)}));return Object.keys(t.skus_availability).some((function(t){return o.includes(Number(t))}))}return this.selectedOptions.some((function(n){return n.is_out&&n.option_id!==t.option_id}))};t.prototype.singleOption=function(t){var n=this;return h("div",null,h("select",{name:"options[".concat(t.id,"]"),required:!t.visibility_condition&&t.required,class:"s-form-control",onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}},h("option",{value:""},t.placeholder),t===null||t===void 0?void 0:t.details.map((function(t){return h("option",{value:t.id,disabled:n.canDisabled&&n.isOptionDetailOut(t),selected:t.is_selected},n.getOptionDetailName(t))}))))};t.prototype.multipleOptions=function(t){var n=this;var e=t.required&&!t.details.some((function(t){return t.is_selected}))&&!t.visibility_condition;return h("div",{class:{"s-product-options-multiple-options-wrapper":true,required:t.required}},t===null||t===void 0?void 0:t.details.map((function(i){return h("div",null,h("input",{type:"checkbox",value:i.id,disabled:n.isOptionDetailOut(i),checked:i.is_selected,required:e,name:"options[".concat(t.id,"][]"),id:"field-".concat(t.id,"-").concat(i.id),onChange:function(e){return n.changedHandler(e,t)},onInvalid:function(e){return n.invalidHandler(e,t)},"aria-describedby":"options[".concat(t.id,"]-description")}),h("label",{htmlFor:"field-".concat(t.id,"-").concat(i.id)},n.getOptionDetailName(i)))})))};t.prototype.colorOption=function(t){var n=this;return h("fieldset",{class:"s-product-options-colors-wrapper"},t===null||t===void 0?void 0:t.details.map((function(e){return h("div",{class:"s-product-options-colors-item"},h("input",{type:"radio",value:e.id,required:!t.visibility_condition&&t.required,checked:e.is_selected,name:"options[".concat(t.id,"]"),disabled:n.canDisabled&&n.isOptionDetailOut(e),id:"color-".concat(n.productId,"-").concat(t.id,"-").concat(e.id),onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}}),h("label",{htmlFor:"color-".concat(n.productId,"-").concat(t.id,"-").concat(e.id)},h("span",{style:{"background-color":e.color}}),h("div",{innerHTML:n.getOptionDetailName(e,true,t.type)})))})))};t.prototype.thumbnailOption=function(t){var n=this;return h("div",{class:"s-product-options-thumbnails-wrapper"},t.details.map((function(e){return h("div",null,h("input",{type:"radio",value:e.id,"data-itemid":e.id,required:!t.visibility_condition&&t.required,checked:e.is_selected,name:"options[".concat(t.id,"]"),"data-img-id":e.option_value,disabled:n.canDisabled&&n.isOptionDetailOut(e),id:"option_".concat(n.productId,"-").concat(t.id,"_").concat(e.id),onInvalid:function(e){return n.invalidHandler(e,t)},onChange:function(e){return n.changedHandler(e,t)}}),h("label",{htmlFor:"option_".concat(n.productId,"-").concat(t.id,"_").concat(e.id),"data-img-id":e.option_value,class:"go-to-slide"},h("img",{"data-src":e.image,src:e.image,title:e.name,alt:e.name}),h("span",{innerHTML:CheckCircleIcon,class:"s-product-options-thumbnails-icon"}),n.isOptionDetailOut(e)?[h("small",{class:"s-product-options-thumbnails-stock-badge"},n.outOfStockText),n.canDisabled?h("div",{class:"s-product-options-thumbnails-badge-overlay"}):""]:""),h("p",null,n.getOptionDetailName(e,false)," "))})))};Object.defineProperty(t.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return t}();SallaProductOptions.style=sallaProductOptionsCss;export{SallaProductOptions as salla_product_options};
5
5
  //# sourceMappingURL=salla-product-options.entry.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["DisplayType","Currency","sallaProductOptionsCss","SallaProductOptions","class_1","hostRef","_this","this","fileTypes","pdf","png","jpg","word","exl","txt","outSkus","handleDonationOptions","event","detail","type","salla","helpers","inputDigitsOnly","target","emit","id","productId","price","value","preventDefault","stopPropagation","isCustomDonation","donationInput","focus","hideLabel","option","DONATION","donation","can_donate","getExpireDonationMessage","completed","target_amount","collected_amount","h","class","target_message","money","lang","get","getWithDefault","config","canDisabled","onLoaded","outOfStockText","donationAmount","selectDonationAmount","selectAmount","options","setOptionsData","Array","isArray","JSON","parse","e","log","optionsData","url","is_page","api","product","getDetails","then","resp","data","prototype","that","_b","_a","details","forEach","Object","entries","skus_availability","filter","sku","map","push","Number","getSelectedOptionsData","selectedOptions","formData","host","getElementSallaData","key","startsWith","replace","reportValidity","requiredElements","querySelectorAll","pass","i","length","hasOutOfStockOption","some","is_out","selectedSkus","every","includes","getSelectedOptions","getOption","option_id","find","invalidHandler","closestProductOption","closest","scrollIntoView","behavior","block","classList","add","changedHandler","optionElement","FILE","IMAGE","MAP","lat","lng","setTimeout","remove","index","findIndex","assign","setSelectedSkus","handleRequiredMultipleOptions","changed","keys","reduce","p","c","MULTIPLE_OPTIONS","required","optionContainer","querySelector","concat","hasChecked","input","toggleAttribute","getLatLng","split","getDisplayForType","COLOR_PICKER","colorPickerOption","multipleOptions","SINGLE_OPTION","singleOption","getOptionShownWhen","visibility_condition","operator","componentWillLoad","cart","getCurrentCartId","componentDidRender","selectedDonationOption","is_selected","additional_price","render","Host","name","splitterOption","htmlFor","placeholder","donationOption","checked","onChange","custom_amount_enabled","shown","ref","el","onInput","onBlur","onInvalid","currency","symbol","fileUploader","additions","height","onAdded","getUploadImageEndpoint","cart_item_id","product_id","onInvalidInput","innerHTML","accept","CameraIcon","FileIcon","imageOption","fileOption","types","Boolean","join","numberOption","textOption","textareaOption","rows","mapOption","zoom","searchable","onSelected","onSubmitted","color","timeOption","noCalendar","enableTime","dateFormat","onPicked","dateOption","minDate","Date","datetimeOption","maxDate","to_date_time","from_date_time","getOptionDetailName","outOfStock","optionType","COLOR","isOptionDetailOut","isDetailSelected","outSelectableSkus_1","disabled","selected","is_required","colorOption","style","thumbnailOption","option_value","image","src","title","alt","CheckCircleIcon"],"sources":["src/components/salla-product-options/interfaces.ts","src/components/salla-product-options/salla-product-options.scss?tag=salla-product-options","src/components/salla-product-options/salla-product-options.tsx"],"sourcesContent":["export enum DisplayType {\n COLOR = \"color\",\n DATE = \"date\",\n DATETIME = \"datetime\",\n DONATION = \"donation\",\n IMAGE = \"image\",\n MULTIPLE_OPTIONS = \"multiple-options\",\n NUMBER = \"number\",\n SINGLE_OPTION = \"single-option\",\n SPLITTER = \"splitter\",\n TEXT = \"text\",\n TEXTAREA = \"textarea\",\n THUMBNAIL = \"thumbnail\",\n TIME = \"time\",\n RADIO = \"radio\",\n CHECKBOX = \"checkbox\",\n MAP = \"map\",\n FILE = \"file\", // similar to image type (file-uploader component)\n COLOR_PICKER = \"color_picker\"\n\n}\n\nexport interface ProductDetail {\n id: string;\n sku: string;\n name: string;\n description: string;\n url: string;\n promotion_title: string;\n subtitle: string;\n type: string;\n status: string;\n price: number;\n sale_price: number;\n regular_price: number;\n starting_price: null;\n quantity: number;\n max_quantity: number;\n discount_ends: number;\n is_taxable: boolean;\n has_read_more: boolean;\n can_add_note: boolean;\n can_show_remained_quantity: boolean;\n can_upload_file: boolean;\n has_custom_form: boolean;\n is_on_sale: boolean;\n is_hidden_quantity: boolean;\n is_available: boolean;\n is_out_of_stock: boolean;\n weight: null;\n calories: null;\n image: SimpleImage;\n brand: Brand;\n donation?: ProductDonation;\n images: Image[];\n tags: Tag[];\n notify_availability: null;\n rating: Rating;\n options: Option[];\n sold_quantity: number;\n category: Category;\n}\n\nexport interface SimpleImage {\n url: string;\n alt: string;\n}\n\nexport interface Category {\n name: string;\n url: string;\n icon: string;\n}\n\nexport interface ProductDonation {\n target_message?: string;\n collected_amount?: number;\n target_amount?: number;\n target_percent?: number;\n target_end_date?: string;\n can_donate: boolean;\n custom_amount_enabled: boolean;\n}\n\nexport interface Image {\n id: number;\n url: string;\n main: boolean;\n three_d_image_url: string;\n alt: string;\n video_url: string;\n type: string;\n sort: number;\n}\n\nexport interface Option {\n id: number;\n name: string;\n required: boolean;\n type: string;\n placeholder: string;\n option_type: string;\n not_same_day_order: boolean;\n availability_range: number;\n from_date_time: null;\n to_date_time: null;\n visibility_condition?: { option: number, operator: \"=\" | \"!=\", value: number };\n details?: Detail[];\n condition_attributes: string;\n value?: any;\n donation?: Donation\n}\n\nexport interface Donation {\n custom_amount_enabled: boolean;\n target_message?: string;\n target_date: string | \"2023-04-18\";\n target_end_date: string | \"2023-04-18\";\n target_amount: number;\n collected_amount: number;\n can_donate: boolean;\n}\n\nexport interface Detail {\n id: number;\n option_id: number;\n name: string;\n additional_price: number;\n option_value: null | string;\n image: null | string;\n color: null | string;\n is_out: boolean;\n skus_availability?: { [sku_id: number]: boolean };\n is_selected: boolean;\n}\n\nexport interface Brand {\n id: string;\n url: string;\n name: string;\n logo: string;\n}\n\nexport interface PreTaxPrice {\n amount: number;\n currency: Currency;\n}\n\nexport enum Currency {\n Sar = \"SAR\",\n}\n\nexport interface Promotion {\n title: string;\n sub_title: string;\n}\n\nexport interface Rating {\n count: number;\n stars: number;\n}\n\nexport interface Tag {\n name: string;\n url: string;\n}\n","\n.s-product-options{\n &-wrapper{\n\n }\n &-option-container{\n\n }\n &-option{\n\n }\n &-option-label{\n\n }\n &-option-content{\n\n }\n &-colors-wrapper{\n\n }\n &-date-element{\n\n }\n &-time-element{\n \n }\n &-datetime-element{\n\n }\n &-image-input{\n\n }\n &-multiple-options-wrapper{\n\n }\n &-splitter{\n\n }\n &-text{\n\n }\n &-textarea{\n\n }\n &-thumbnails-wrapper{\n\n }\n}","import { Component, Prop, h, State, Element, Host, Event, EventEmitter, Method } from '@stencil/core';\nimport { Option, DisplayType, Detail } from './interfaces';\nimport CheckCircleIcon from '../../assets/svg/check.svg';\nimport CameraIcon from '../../assets/svg/camera.svg';\nimport FileIcon from '../../assets/svg/file-upload.svg';\n\n\n@Component({\n tag: 'salla-product-options',\n styleUrl: 'salla-product-options.scss',\n})\nexport class SallaProductOptions {\n\n constructor() {\n this.canDisabled = !salla.config.get('store.settings.product.notify_options_availability');\n salla.lang.onLoaded(() => {\n this.outOfStockText = salla.lang.get(\"pages.products.out_of_stock\");\n this.donationAmount = salla.lang.get('pages.products.donation_amount');\n this.selectDonationAmount = salla.lang.getWithDefault('pages.products.select_donation_amount', 'تحديد مبلغ التبرع');\n this.selectAmount = salla.lang.getWithDefault('pages.products.select_amount', 'اختر المبلغ');\n });\n\n if (this.options) {\n try {\n this.setOptionsData(Array.isArray(this.options) ? this.options : JSON.parse(this.options));\n return;\n } catch (e) {\n salla.log('Bad json passed via options prop');\n }\n }\n if (!Array.isArray(this.optionsData)) {\n salla.log('Options is not an array[] ---> ', this.optionsData);\n this.setOptionsData([]);\n }\n\n if (this.productId && !salla.url.is_page('cart')) {\n salla.api.product.getDetails(this.productId, ['options']).then(resp => this.setOptionsData(resp.data.options));\n }\n }\n\n private setOptionsData(optionsData: Option[]) {\n this.optionsData = optionsData;\n let that = this\n this.optionsData[0]?.details?.forEach(function (detail) {\n Object.entries(detail.skus_availability || {})\n .filter(sku => !sku[1])\n .map(sku => that.outSkus.push(Number(sku[0])));\n });\n }\n\n @Element() host: HTMLElement;\n\n private fileTypes: Object = {\n pdf: 'application/pdf',\n png: 'image/png',\n jpg: 'image/jpeg',\n word: 'application/doc,application/ms-doc,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n exl: 'application/excel,application/vnd.ms-excel,application/x-excel,application/x-msexcel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n txt: 'text/plain',\n };\n\n @State() optionsData: Option[];\n @State() outOfStockText: string = ''\n @State() donationAmount: string = salla.lang.get('pages.products.donation_amount')\n @State() selectDonationAmount: string = salla.lang.getWithDefault('pages.products.select_donation_amount', 'تحديد مبلغ التبرع')\n @State() selectAmount: string = salla.lang.getWithDefault('pages.products.select_amount', 'اختر المبلغ')\n @State() isCustomDonation: boolean = false;\n @State() selectedOptions: Array<any> = [];\n @State() canDisabled: boolean;\n @State() selectedSkus?: Array<string | number>;\n @State() selectedOutSkus?: Array<string | number>;\n private outSkus: Array<string | number> = [];\n private donationInput?: HTMLInputElement;\n\n /**\n * The id of the product to which the options are going to be fetched for.\n */\n @Prop() productId: number = salla.config.get('page.id');\n\n /**\n * Product detail information.\n */\n @Prop() options: string;\n\n /**\n * Get the id's of the selected options.\n * */\n @Method()\n async getSelectedOptionsData() {\n let selectedOptions = {}\n let formData = (this.host as any).getElementSallaData();\n formData.forEach(function (value, key) {\n key.startsWith('options[') && (selectedOptions[key.replace('options[', '').replace(']', '')] = value);\n });\n return selectedOptions;\n }\n\n /**\n * Report options form validity.\n * */\n @Method()\n async reportValidity() {\n let requiredElements: Array<HTMLInputElement> = this.host.querySelectorAll('[required]') as any;\n let pass = true;\n for (let i = 0; i < requiredElements.length; i++) {\n //if there is only one invalid option, return false\n if ('reportValidity' in requiredElements[i] && !requiredElements[i].reportValidity()) {\n pass = false;\n }\n }\n return pass;\n }\n\n /**\n * Return true if there is any out of stock options are selected and vise versa.\n * */\n @Method()\n async hasOutOfStockOption() {\n return this.selectedOptions.some(option => option.is_out) || (this.selectedSkus?.length && this.selectedSkus?.every(sku => this.outSkus.includes(sku)));\n }\n\n /**\n * Get selected options.\n * */\n @Method()\n async getSelectedOptions() {\n return this.selectedOptions;\n }\n\n /**\n * Get a specific option by its id.\n * */\n @Method()\n async getOption(option_id) {\n return this.optionsData.find(option => option.id === option_id);\n }\n\n /**\n * An event that emitted when any option is changed.\n */\n @Event() changed: EventEmitter;\n\n // @ts-ignore\n private invalidHandler(event, option: Option) {\n const closestProductOption = (event.target as HTMLInputElement).closest('.s-product-options-option') as HTMLElement;\n if (!salla.url.is_page('cart')) {\n closestProductOption.scrollIntoView({ behavior: 'smooth', block: 'center' });\n }\n closestProductOption.classList.add('s-product-options-option-error');\n }\n\n private changedHandler(event, option) {\n let data = { event: event, option: option, detail: null };\n if (option.details) {\n let detail = option.details.find((detail) => {\n return Number(detail.id) === Number(event.target.value);\n });\n data.detail = detail\n }\n\n let optionElement = event.target.closest('.s-product-options-option');\n if (event.target.value\n || ((option.type == DisplayType.FILE || option.type == DisplayType.IMAGE) && event.type === 'added')\n || (option.type == DisplayType.MAP && event.type === 'selected' && (event.target.lat && event.target.lng))) {\n setTimeout(() => {\n optionElement.classList.remove('s-product-options-option-error');\n }, 200);\n }\n\n const index = this.selectedOptions.findIndex(option => option.option_id === data.option.id);\n index > -1 ? this.selectedOptions[index] = {\n ...data.detail,\n option_id: data.option.id\n } : this.selectedOptions.push({ ...data.detail, option_id: data.option.id })\n\n if (option.type == DisplayType.DONATION) {\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n }\n this.setSelectedSkus();\n this.handleRequiredMultipleOptions(option);\n this.changed.emit(data);\n salla.event.emit('product-options::change', data);\n }\n\n\n private handleDonationOptions = (event, detail, type) => {\n if (detail == 'custom' && type == 'input') {\n salla.helpers.inputDigitsOnly(event.target)\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.isCustomDonation = event.target.value === 'custom';\n if (this.donationInput) {\n if (event.target.value === 'custom') {\n this.donationInput.value = '';\n this.donationInput.focus()\n } else {\n this.donationInput.value = event.target.value;\n }\n if (detail == 'custom') {\n return\n }\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n }\n }\n\n private hideLabel = (option) => {\n if (option.type === DisplayType.DONATION && (option.donation && !option.donation.can_donate)) {\n return true;\n }\n return false;\n }\n\n private getExpireDonationMessage = (option) => {\n if (!option.donation) {\n return;\n }\n let completed = option.donation.target_amount <= option.donation.collected_amount;\n return <div class={{ \"s-product-options-donation-message\": true, \"s-product-options-donation-completed\": completed, \"s-product-options-donation-expired\": !completed }}>\n <p>{option.donation.target_message}</p>\n <span>{completed ? salla.money(option.donation.target_amount) : ''}</span>\n </div>\n }\n /**\n * loop throw all selected details, then get common sku, if it's only one, means we selected all of them;\n */\n private setSelectedSkus() {\n this.selectedSkus = this.selectedOptions.map(detail => Object.keys(detail.skus_availability || {}))\n .reduce((p, c) => p.filter(e => c.includes(e)))\n .map(sku => Number(sku));\n }\n\n private handleRequiredMultipleOptions(option) {\n if (option.type !== DisplayType.MULTIPLE_OPTIONS || !option.required) {\n return;\n }\n const optionContainer = this.host.querySelector(`[data-option-id=\"${option.id}\"]`);\n const hasChecked = optionContainer.querySelectorAll('input:checked').length;\n optionContainer.querySelectorAll('input').forEach(input => input.toggleAttribute('required', !hasChecked));\n }\n\n private getLatLng(value, type: 'lat' | 'lng') {\n return value\n ? value.split(',')[type == 'lat' ? 0 : 1]\n : '';\n }\n\n private getDisplayForType(option: Option) {\n if (this[`${option.type}Option`]) {\n return this[`${option.type}Option`](option);\n }\n\n if (option.type === DisplayType.COLOR_PICKER) {\n return this.colorPickerOption(option)\n }\n\n if (option.type === DisplayType.MULTIPLE_OPTIONS) {\n return this.multipleOptions(option);\n }\n\n if (option.type === DisplayType.SINGLE_OPTION) {\n return this.singleOption(option);\n }\n salla.log(`Couldn't find options type(${option.type})😢`);\n return '';\n }\n\n protected getOptionShownWhen(option: Option) {\n return option.visibility_condition\n ? { \"data-show-when\": `options[${option.visibility_condition.option}] ${option.visibility_condition.operator} ${option.visibility_condition.value}` }\n : {};\n }\n\n //we need the cart Id for productOption Image\n componentWillLoad() {\n this.outOfStockText = salla.lang.get('pages.products.out_of_stock')\n return salla.api.cart.getCurrentCartId();\n }\n\n componentDidRender() {\n if (this.optionsData?.length == 0 && !this.optionsData.some(option => option.type == DisplayType.DONATION)) {\n return;\n }\n let selectedDonationOption = this.optionsData.find(option => option.type == DisplayType.DONATION)?.details.find(detail => detail.is_selected);\n if (!selectedDonationOption) {\n return;\n }\n setTimeout(() => {\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: selectedDonationOption.additional_price\n });\n }, 1000);\n }\n\n render() {\n if (this.optionsData?.length == 0) {\n return;\n }\n\n return (\n <Host class=\"s-product-options-wrapper\">\n {/* TODO:: move salla-conditional-field logic to here, no need of another component*/}\n <salla-conditional-fields>\n {this.optionsData.map((option: Option) =>\n <div class={`s-product-options-option-container${option.visibility_condition ? ' hidden' : ''}`}\n data-option-id={option.id}\n {...this.getOptionShownWhen(option)}>\n {option.name == 'splitter' ?\n this.splitterOption()\n : <div class=\"s-product-options-option\" data-option-type={option.type}\n data-option-required={`${option.required}`}>\n <label htmlFor={'options[' + option.id + ']'} class={`s-product-options-option-label ${this.hideLabel(option) ? 's-product-options-option-label-hidden' : ''}`}>\n <b>\n {option.name}\n {option.required && <span> * </span>} </b>\n <small>{option.placeholder}</small>\n </label>\n <div class={`s-product-options-option-content ${this.hideLabel(option) ? 's-product-options-option-content-full-width' : ''}`}>\n {this.getDisplayForType(option)}\n </div>\n </div>}\n </div>\n )}\n </salla-conditional-fields>\n </Host>\n );\n\n }\n\n //@ts-ignore\n private donationOption(option: Option, product: Product) {\n return <div class=\"s-product-options-donation-wrapper\">\n\n {option.donation?.can_donate ? [\n option.donation ?\n <div class=\"s-product-options-donation-progress\">\n <salla-progress-bar donation={option.donation}>\n </salla-progress-bar>\n </div>\n : '',\n option.details.length ?\n [<h4>{this.selectAmount}</h4>,\n <div class=\"s-product-options-donation-options\">\n {option.details.map((detail, i) =>\n <div class=\"s-product-options-donation-options-item\">\n <input id={`donation-option-${i}`} type=\"radio\" name=\"donating_option\" checked={detail.is_selected} value={detail.additional_price} onChange={e => this.handleDonationOptions(e, detail, 'option')} />\n <label htmlFor={`donation-option-${i}`}>\n <span>{salla.money(detail.name)}</span>\n </label>\n </div>\n )}\n {option.donation?.custom_amount_enabled ?\n <div class=\"s-product-options-donation-options-item\">\n <input id={`donation-option-custom`} type=\"radio\" name=\"donating_option\" value=\"custom\" onChange={e => this.handleDonationOptions(e, 'custom', 'option')} />\n <label htmlFor={`donation-option-custom`}>\n <span> {this.selectDonationAmount} </span>\n </label>\n </div>\n : ''\n }\n </div>] : '',\n\n <div class={{ \"s-product-options-donation-input-group\": true, \"shown\": !option.details.length || (option.details.length && this.isCustomDonation) }}>\n <input\n type=\"text\"\n id=\"donating-amount\"\n name=\"donation_amount\"\n class=\"s-form-control\"\n ref={el => this.donationInput = el as HTMLInputElement}\n value={\n option.details.length\n && option.details.some(detail => detail.is_selected)\n ? option.details.find(detail => detail.is_selected).additional_price\n : option.value}\n // required\n placeholder={option.placeholder}\n onInput={e => this.handleDonationOptions(e, 'custom', 'input')}\n onBlur={e => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n />\n {/* value={option.value} */}\n <span class=\"s-product-options-donation-amount-currency\">\n {salla.config.currency(salla.config.get('user.currency_code')).symbol}\n </span>\n </div>\n ] :\n this.getExpireDonationMessage(option)\n }\n </div>\n }\n\n private fileUploader(option: Option, additions: Object | null = null) {\n return <salla-file-upload\n {...(additions || {})}\n payload-name=\"file\"\n value={option.value}\n instant-upload={true}\n name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n height=\"120px\"\n onAdded={(e) => this.changedHandler(e, option)}\n url={salla.cart.api.getUploadImageEndpoint()}\n form-data={{ cart_item_id: this.productId, product_id: this.productId }}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n class={{ \"s-product-options-image-input\": true, required: option.required }}\n >\n <div class=\"s-product-options-filepond-placeholder\">\n <span class=\"s-product-options-filepond-placeholder-icon\"\n innerHTML={(additions as any).accept && (additions as any).accept.split(',').every(type => type.includes('image'))\n ? CameraIcon\n : FileIcon}\n />\n <p class=\"s-product-options-filepond-placeholder-text\">{salla.lang.get('common.uploader.drag_and_drop')}</p>\n <span class=\"filepond--label-action\">{salla.lang.get('common.uploader.browse')}</span>\n </div>\n </salla-file-upload>\n }\n\n //@ts-ignore\n private imageOption(option: Option) {\n return this.fileUploader(option, { accept: 'image/png,image/jpeg,image/jpg,image/gif' });\n }\n\n //@ts-ignore\n private fileOption(option: Option) {\n let types = option.details.map(detail => this.fileTypes[detail.name]).filter(Boolean);\n return types?.length\n ? this.fileUploader(option, { accept: types.join(',') })\n : 'File types not selected.';\n }\n\n // TODO: (ONLY FOR TESTING!) find a better way to make it testable, e.g. wrap it with a unique class like textOption\n //@ts-ignore\n private numberOption(option: Option) {\n return <input\n type=\"text\"\n value={option.value}\n class=\"s-form-control\"\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onBlur={e => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={e => salla.helpers.inputDigitsOnly(e.target)} />\n }\n\n //@ts-ignore\n private splitterOption() {\n return <div class=\"s-product-options-splitter\" />\n }\n\n //@ts-ignore\n private textOption(option: Option) {\n return <div class=\"s-product-options-text\">\n <input\n type=\"text\"\n value={option.value}\n class='s-form-control'\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={e => this.changedHandler(e, option)} />\n </div>\n }\n\n //@ts-ignore\n private textareaOption(option: Option) {\n //todo::remove mt-1 class, and if it's okay to remove the tag itself will be great\n return <div class=\"s-product-options-textarea\">\n <div class=\"mt-1\">\n <textarea\n rows={4}\n value={option.value}\n class=\"s-form-control\"\n required={!option.visibility_condition && option.required}\n id={`options[${option.id}]`}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={(e) => this.changedHandler(e, option)} />\n </div>\n </div>\n }\n\n //@ts-ignore\n private mapOption(option: Option) {\n return <salla-map\n zoom={15}\n lat={this.getLatLng(option.value, 'lat')}\n lng={this.getLatLng(option.value, 'lng')}\n name={`options[${option.id}]`}\n searchable={true}\n required={option.required}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onSelected={e => this.changedHandler(e, option)} />\n }\n\n private colorPickerOption(option: Option) {\n return <salla-color-picker\n onSubmitted={e => this.changedHandler(e, option)}\n name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n color={option.value} />\n }\n\n /**\n * ============= Date Time options =============\n */\n //@ts-ignore\n private timeOption(option: Option) {\n return <salla-datetime-picker\n noCalendar={true}\n enableTime={true}\n dateFormat=\"h:i K\"\n value={option.value}\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n class=\"s-product-options-time-element\"\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n }\n\n //@ts-ignore\n private dateOption(option: Option) {\n //todo:: consider date-range @see https://github.com/SallaApp/theme-raed/blob/master/src/assets/js/partials/product-options.js#L8-L23\n return <div class=\"s-product-options-date-element\">\n <salla-datetime-picker\n value={option.value}\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n minDate={new Date()}\n name={`options[${option.id}]`}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n </div>\n }\n\n //@ts-ignore\n private datetimeOption(option: Option) {\n //todo:: consider date-range @see https://github.com/SallaApp/theme-raed/blob/master/src/assets/js/partials/product-options.js#L8-L23\n return <div class=\"s-product-options-datetime-element\">\n <salla-datetime-picker\n enableTime={true}\n value={option.value}\n dateFormat=\"Y-m-d G:i:K\"\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n maxDate={option.to_date_time}\n minDate={option.from_date_time}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n </div>\n }\n\n /**\n * ============= Advanced options =============\n */\n protected getOptionDetailName(detail: Detail, outOfStock: boolean = true, optionType?: string) {\n if (optionType && optionType == DisplayType.COLOR) {\n return detail.name\n + ((outOfStock && this.isOptionDetailOut(detail)) ? ` <br/> <p> ${this.outOfStockText} </p>` : '')\n + (detail.additional_price ? ` <p> (${salla.money(detail.additional_price)}) </p>` : '');\n }\n\n return detail.name\n + ((outOfStock && this.isOptionDetailOut(detail)) ? ` - ${this.outOfStockText}` : '')\n + (detail.additional_price ? ` (${salla.money(detail.additional_price)})` : '');\n }\n\n\n protected isOptionDetailOut(detail: Detail) {\n if (detail.is_out || !detail.skus_availability || !this.selectedSkus?.length) {\n return detail.is_out;\n }\n\n let isDetailSelected = this.selectedOptions.filter(option => option.id == detail.id).length;\n //if the current options is the only selected option, so we are sure that it's not out, because there is no other options selected yet\n if (isDetailSelected && this.selectedOptions.length == 1) {\n return false;\n }\n\n //if current details has sku in the possible outSkus it's out for sure\n if (isDetailSelected) {\n //here we will get the possible outSkus for current selected options\n let outSelectableSkus = this.selectedSkus.filter(sku => this.outSkus.includes(sku));\n return Object.keys(detail.skus_availability).some(sku => outSelectableSkus.includes(Number(sku)))\n }\n\n return this.selectedOptions.some(option => option.is_out && option.option_id !== detail.option_id)\n\n }\n\n private singleOption(option: Option) {\n return <div>\n <select name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n class=\"s-form-control\"\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={e => this.changedHandler(e, option)}>\n <option value=\"\">{option.placeholder}</option>\n {\n option?.details.map((detail: Detail) => {\n return <option value={detail.id} disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n selected={detail.is_selected}>\n {this.getOptionDetailName(detail)}\n </option>\n })\n }\n </select>\n </div>\n }\n\n private multipleOptions(option: Option) {\n let is_required = option.required && !option.details.some(detail => detail.is_selected) && !option.visibility_condition;\n return <div class={{ \"s-product-options-multiple-options-wrapper\": true, 'required': option.required }}>\n {\n option?.details.map((detail: Detail) => {\n return <div>\n <input type=\"checkbox\"\n value={detail.id}\n disabled={this.isOptionDetailOut(detail)}\n checked={detail.is_selected}\n required={is_required}\n name={`options[${option.id}][]`}\n id={`field-${option.id}-${detail.id}`}\n onChange={(e) => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n aria-describedby={`options[${option.id}]-description`} />\n <label htmlFor={`field-${option.id}-${detail.id}`}>{this.getOptionDetailName(detail)}</label>\n </div>\n })\n }\n </div>\n }\n\n //@ts-ignore\n private colorOption(option: Option) {\n return <fieldset class=\"s-product-options-colors-wrapper\">\n {\n option?.details.map((detail) =>\n <div class=\"s-product-options-colors-item\">\n <input type=\"radio\"\n value={detail.id}\n required={!option.visibility_condition && option.required}\n checked={detail.is_selected}\n name={`options[${option.id}]`}\n disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n id={`color-${this.productId}-${option.id}-${detail.id}`}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={e => this.changedHandler(e, option)} />\n <label htmlFor={`color-${this.productId}-${option.id}-${detail.id}`}>\n <span style={{ \"background-color\": detail.color }} />\n <div innerHTML={this.getOptionDetailName(detail, true, option.type)}></div>\n </label>\n </div>\n )\n }\n </fieldset>\n }\n\n //@ts-ignore\n private thumbnailOption(option: Option) {\n return <div class=\"s-product-options-thumbnails-wrapper\">\n {option.details.map((detail: Detail) => {\n return <div>\n <input type=\"radio\"\n value={detail.id}\n data-itemid={detail.id} //todo:: why need this? it's already in the value!\n required={!option.visibility_condition && option.required}\n checked={detail.is_selected}\n name={`options[${option.id}]`}\n data-img-id={detail.option_value}\n disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n id={`option_${this.productId}-${option.id}_${detail.id}`}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={(e) => this.changedHandler(e, option)} />\n <label htmlFor={`option_${this.productId}-${option.id}_${detail.id}`}\n data-img-id={detail.option_value}\n class=\"go-to-slide\">\n <img data-src={detail.image} src={detail.image} title={detail.name} alt={detail.name} />\n <span innerHTML={CheckCircleIcon} class=\"s-product-options-thumbnails-icon\" />\n {this.isOptionDetailOut(detail) ?\n [\n <small class=\"s-product-options-thumbnails-stock-badge\">{this.outOfStockText}</small>,\n this.canDisabled ? <div class=\"s-product-options-thumbnails-badge-overlay\" /> : '',\n ]\n : ''}\n </label>\n <p>{this.getOptionDetailName(detail, false)} </p>\n </div>\n })}\n </div>\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["DisplayType","Currency","sallaProductOptionsCss","SallaProductOptions","class_1","hostRef","_this","this","fileTypes","pdf","png","jpg","word","exl","txt","outSkus","handleDonationOptions","event","detail","type","salla","helpers","inputDigitsOnly","target","emit","id","productId","price","value","preventDefault","stopPropagation","isCustomDonation","donationInput","focus","hideLabel","option","DONATION","donation","can_donate","getExpireDonationMessage","completed","target_amount","collected_amount","h","class","target_message","money","lang","get","getWithDefault","config","canDisabled","onLoaded","outOfStockText","donationAmount","selectDonationAmount","selectAmount","options","setOptionsData","Array","isArray","JSON","parse","e","log","optionsData","url","is_page","api","product","getDetails","then","resp","data","prototype","that","_b","_a","details","forEach","Object","entries","skus_availability","filter","sku","map","push","Number","getSelectedOptionsData","selectedOptions","formData","host","getElementSallaData","key","startsWith","replace","reportValidity","requiredElements","querySelectorAll","pass","i","length","hasOutOfStockOption","some","is_out","selectedSkus","every","includes","getSelectedOptions","getOption","option_id","find","invalidHandler","closestProductOption","closest","scrollIntoView","behavior","block","classList","add","changedHandler","optionElement","FILE","IMAGE","MAP","lat","lng","setTimeout","remove","index","findIndex","assign","setSelectedSkus","handleRequiredMultipleOptions","changed","keys","reduce","p","c","MULTIPLE_OPTIONS","required","optionContainer","querySelector","concat","hasChecked","input","toggleAttribute","getLatLng","split","getDisplayForType","COLOR_PICKER","colorPickerOption","multipleOptions","SINGLE_OPTION","singleOption","getOptionShownWhen","visibility_condition","operator","componentWillLoad","cart","getCurrentCartId","componentDidRender","selectedDonationOption","is_selected","additional_price","render","Host","name","splitterOption","htmlFor","placeholder","donationOption","checked","onChange","custom_amount_enabled","shown","ref","el","onInput","onBlur","onInvalid","currency","symbol","fileUploader","additions","height","onAdded","getUploadImageEndpoint","cart_item_id","product_id","onInvalidInput","innerHTML","accept","CameraIcon","FileIcon","imageOption","fileOption","types","Boolean","join","numberOption","textOption","textareaOption","rows","mapOption","zoom","searchable","onSelected","onSubmitted","color","timeOption","noCalendar","enableTime","dateFormat","onPicked","dateOption","minDate","Date","datetimeOption","maxDate","to_date_time","from_date_time","getOptionDetailName","outOfStock","optionType","COLOR","isOptionDetailOut","isDetailSelected","outSelectableSkus_1","disabled","selected","is_required","colorOption","style","thumbnailOption","option_value","image","src","title","alt","CheckCircleIcon"],"sources":["src/components/salla-product-options/interfaces.ts","src/components/salla-product-options/salla-product-options.scss?tag=salla-product-options","src/components/salla-product-options/salla-product-options.tsx"],"sourcesContent":["export enum DisplayType {\n COLOR = \"color\",\n DATE = \"date\",\n DATETIME = \"datetime\",\n DONATION = \"donation\",\n IMAGE = \"image\",\n MULTIPLE_OPTIONS = \"multiple-options\",\n NUMBER = \"number\",\n SINGLE_OPTION = \"single-option\",\n SPLITTER = \"splitter\",\n TEXT = \"text\",\n TEXTAREA = \"textarea\",\n THUMBNAIL = \"thumbnail\",\n TIME = \"time\",\n RADIO = \"radio\",\n CHECKBOX = \"checkbox\",\n MAP = \"map\",\n FILE = \"file\", // similar to image type (file-uploader component)\n COLOR_PICKER = \"color_picker\"\n\n}\n\nexport interface ProductDetail {\n id: string;\n sku: string;\n name: string;\n description: string;\n url: string;\n promotion_title: string;\n subtitle: string;\n type: string;\n status: string;\n price: number;\n sale_price: number;\n regular_price: number;\n starting_price: null;\n quantity: number;\n max_quantity: number;\n discount_ends: number;\n is_taxable: boolean;\n has_read_more: boolean;\n can_add_note: boolean;\n can_show_remained_quantity: boolean;\n can_upload_file: boolean;\n has_custom_form: boolean;\n is_on_sale: boolean;\n is_hidden_quantity: boolean;\n is_available: boolean;\n is_out_of_stock: boolean;\n weight: null;\n calories: null;\n image: SimpleImage;\n brand: Brand;\n donation?: ProductDonation;\n images: Image[];\n tags: Tag[];\n notify_availability: null;\n rating: Rating;\n options: Option[];\n sold_quantity: number;\n category: Category;\n}\n\nexport interface SimpleImage {\n url: string;\n alt: string;\n}\n\nexport interface Category {\n name: string;\n url: string;\n icon: string;\n}\n\nexport interface ProductDonation {\n target_message?: string;\n collected_amount?: number;\n target_amount?: number;\n target_percent?: number;\n target_end_date?: string;\n can_donate: boolean;\n custom_amount_enabled: boolean;\n}\n\nexport interface Image {\n id: number;\n url: string;\n main: boolean;\n three_d_image_url: string;\n alt: string;\n video_url: string;\n type: string;\n sort: number;\n}\n\nexport interface Option {\n id: number;\n name: string;\n required: boolean;\n type: string;\n placeholder: string;\n option_type: string;\n not_same_day_order: boolean;\n availability_range: number;\n from_date_time: null;\n to_date_time: null;\n visibility_condition?: { option: number, operator: \"=\" | \"!=\", value: number };\n details?: Detail[];\n condition_attributes: string;\n value?: any;\n donation?: Donation\n}\n\nexport interface Donation {\n custom_amount_enabled: boolean;\n target_message?: string;\n target_date: string | \"2023-04-18\";\n target_end_date: string | \"2023-04-18\";\n target_amount: number;\n collected_amount: number;\n can_donate: boolean;\n}\n\nexport interface Detail {\n id: number;\n option_id: number;\n name: string;\n additional_price: number;\n option_value: null | string;\n image: null | string;\n color: null | string;\n is_out: boolean;\n skus_availability?: { [sku_id: number]: boolean };\n is_selected: boolean;\n}\n\nexport interface Brand {\n id: string;\n url: string;\n name: string;\n logo: string;\n}\n\nexport interface PreTaxPrice {\n amount: number;\n currency: Currency;\n}\n\nexport enum Currency {\n Sar = \"SAR\",\n}\n\nexport interface Promotion {\n title: string;\n sub_title: string;\n}\n\nexport interface Rating {\n count: number;\n stars: number;\n}\n\nexport interface Tag {\n name: string;\n url: string;\n}\n","\n.s-product-options{\n &-wrapper{\n\n }\n &-option-container{\n\n }\n &-option{\n\n }\n &-option-label{\n\n }\n &-option-content{\n\n }\n &-colors-wrapper{\n\n }\n &-date-element{\n\n }\n &-time-element{\n \n }\n &-datetime-element{\n\n }\n &-image-input{\n\n }\n &-multiple-options-wrapper{\n\n }\n &-splitter{\n\n }\n &-text{\n\n }\n &-textarea{\n\n }\n &-thumbnails-wrapper{\n\n }\n}","import { Component, Prop, h, State, Element, Host, Event, EventEmitter, Method } from '@stencil/core';\nimport { Option, DisplayType, Detail } from './interfaces';\nimport CheckCircleIcon from '../../assets/svg/check.svg';\nimport CameraIcon from '../../assets/svg/camera.svg';\nimport FileIcon from '../../assets/svg/file-upload.svg';\n\n\n@Component({\n tag: 'salla-product-options',\n styleUrl: 'salla-product-options.scss',\n})\nexport class SallaProductOptions {\n\n constructor() {\n this.canDisabled = !salla.config.get('store.settings.product.notify_options_availability');\n salla.lang.onLoaded(() => {\n this.outOfStockText = salla.lang.get(\"pages.products.out_of_stock\");\n this.donationAmount = salla.lang.get('pages.products.donation_amount');\n this.selectDonationAmount = salla.lang.getWithDefault('pages.products.select_donation_amount', 'تحديد مبلغ التبرع');\n this.selectAmount = salla.lang.getWithDefault('pages.products.select_amount', 'اختر المبلغ');\n });\n\n if (this.options) {\n try {\n this.setOptionsData(Array.isArray(this.options) ? this.options : JSON.parse(this.options));\n return;\n } catch (e) {\n salla.log('Bad json passed via options prop');\n }\n }\n if (!Array.isArray(this.optionsData)) {\n salla.log('Options is not an array[] ---> ', this.optionsData);\n this.setOptionsData([]);\n }\n\n if (this.productId && !salla.url.is_page('cart')) {\n salla.api.product.getDetails(this.productId, ['options']).then(resp => this.setOptionsData(resp.data.options));\n }\n }\n\n private setOptionsData(optionsData: Option[]) {\n this.optionsData = optionsData;\n let that = this\n this.optionsData[0]?.details?.forEach(function (detail) {\n Object.entries(detail.skus_availability || {})\n .filter(sku => !sku[1])\n .map(sku => that.outSkus.push(Number(sku[0])));\n });\n }\n\n @Element() host: HTMLElement;\n\n private fileTypes: Object = {\n pdf: 'application/pdf',\n png: 'image/png',\n jpg: 'image/jpeg',\n word: 'application/doc,application/ms-doc,application/msword,application/vnd.openxmlformats-officedocument.wordprocessingml.document',\n exl: 'application/excel,application/vnd.ms-excel,application/x-excel,application/x-msexcel,application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n txt: 'text/plain',\n };\n\n @State() optionsData: Option[];\n @State() outOfStockText: string = ''\n @State() donationAmount: string = salla.lang.get('pages.products.donation_amount')\n @State() selectDonationAmount: string = salla.lang.getWithDefault('pages.products.select_donation_amount', 'تحديد مبلغ التبرع')\n @State() selectAmount: string = salla.lang.getWithDefault('pages.products.select_amount', 'اختر المبلغ')\n @State() isCustomDonation: boolean = false;\n @State() selectedOptions: Array<any> = [];\n @State() canDisabled: boolean;\n @State() selectedSkus?: Array<string | number>;\n @State() selectedOutSkus?: Array<string | number>;\n private outSkus: Array<string | number> = [];\n private donationInput?: HTMLInputElement;\n\n /**\n * The id of the product to which the options are going to be fetched for.\n */\n @Prop() productId: number = salla.config.get('page.id');\n\n /**\n * Product detail information.\n */\n @Prop() options: string;\n\n /**\n * Get the id's of the selected options.\n * */\n @Method()\n async getSelectedOptionsData() {\n let selectedOptions = {}\n let formData = (this.host as any).getElementSallaData();\n formData.forEach(function (value, key) {\n key.startsWith('options[') && (selectedOptions[key.replace('options[', '').replace(']', '')] = value);\n });\n return selectedOptions;\n }\n\n /**\n * Report options form validity.\n * */\n @Method()\n async reportValidity() {\n let requiredElements: Array<HTMLInputElement> = this.host.querySelectorAll('[required]') as any;\n let pass = true;\n for (let i = 0; i < requiredElements.length; i++) {\n //if there is only one invalid option, return false\n if ('reportValidity' in requiredElements[i] && !requiredElements[i].reportValidity()) {\n pass = false;\n }\n }\n return pass;\n }\n\n /**\n * Return true if there is any out of stock options are selected and vise versa.\n * */\n @Method()\n async hasOutOfStockOption() {\n return this.selectedOptions.some(option => option.is_out) || (this.selectedSkus?.length && this.selectedSkus?.every(sku => this.outSkus.includes(sku)));\n }\n\n /**\n * Get selected options.\n * */\n @Method()\n async getSelectedOptions() {\n return this.selectedOptions;\n }\n\n /**\n * Get a specific option by its id.\n * */\n @Method()\n async getOption(option_id) {\n return this.optionsData.find(option => option.id === option_id);\n }\n\n /**\n * An event that emitted when any option is changed.\n */\n @Event() changed: EventEmitter;\n\n // @ts-ignore\n private invalidHandler(event, option: Option) {\n const closestProductOption = (event.target as HTMLInputElement).closest('.s-product-options-option') as HTMLElement;\n if (!salla.url.is_page('cart')) {\n closestProductOption.scrollIntoView({ behavior: 'smooth', block: 'center' });\n }\n closestProductOption.classList.add('s-product-options-option-error');\n }\n\n private changedHandler(event, option) {\n let data = { event: event, option: option, detail: null };\n if (option.details) {\n let detail = option.details.find((detail) => {\n return Number(detail.id) === Number(event.target.value);\n });\n data.detail = detail\n }\n\n let optionElement = event.target.closest('.s-product-options-option');\n if (event.target.value\n || ((option.type == DisplayType.FILE || option.type == DisplayType.IMAGE) && event.type === 'added')\n || (option.type == DisplayType.MAP && event.type === 'selected' && (event.target.lat && event.target.lng))) {\n setTimeout(() => {\n optionElement.classList.remove('s-product-options-option-error');\n }, 200);\n }\n\n const index = this.selectedOptions.findIndex(option => option.option_id === data.option.id);\n index > -1 ? this.selectedOptions[index] = {\n ...data.detail,\n option_id: data.option.id\n } : this.selectedOptions.push({ ...data.detail, option_id: data.option.id })\n\n if (option.type == DisplayType.DONATION) {\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n }\n this.setSelectedSkus();\n this.handleRequiredMultipleOptions(option);\n this.changed.emit(data);\n salla.event.emit('product-options::change', data);\n }\n\n\n private handleDonationOptions = (event, detail, type) => {\n if (detail == 'custom' && type == 'input') {\n salla.helpers.inputDigitsOnly(event.target)\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n return;\n }\n event.preventDefault();\n event.stopPropagation();\n this.isCustomDonation = event.target.value === 'custom';\n if (this.donationInput) {\n if (event.target.value === 'custom') {\n this.donationInput.value = '';\n this.donationInput.focus()\n } else {\n this.donationInput.value = event.target.value;\n }\n if (detail == 'custom') {\n return\n }\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: event.target.value\n });\n }\n }\n\n private hideLabel = (option) => {\n if (option.type === DisplayType.DONATION && (option.donation && !option.donation.can_donate)) {\n return true;\n }\n return false;\n }\n\n private getExpireDonationMessage = (option) => {\n if (!option.donation) {\n return;\n }\n let completed = option.donation.target_amount <= option.donation.collected_amount;\n return <div class={{ \"s-product-options-donation-message\": true, \"s-product-options-donation-completed\": completed, \"s-product-options-donation-expired\": !completed }}>\n <p>{option.donation.target_message}</p>\n <span>{completed ? salla.money(option.donation.target_amount) : ''}</span>\n </div>\n }\n /**\n * loop throw all selected details, then get common sku, if it's only one, means we selected all of them;\n */\n private setSelectedSkus() {\n this.selectedSkus = this.selectedOptions.map(detail => Object.keys(detail.skus_availability || {}))\n .reduce((p, c) => p.filter(e => c.includes(e)))\n .map(sku => Number(sku));\n }\n\n private handleRequiredMultipleOptions(option) {\n if (option.type !== DisplayType.MULTIPLE_OPTIONS || !option.required) {\n return;\n }\n const optionContainer = this.host.querySelector(`[data-option-id=\"${option.id}\"]`);\n const hasChecked = optionContainer.querySelectorAll('input:checked').length;\n optionContainer.querySelectorAll('input').forEach(input => input.toggleAttribute('required', !hasChecked));\n }\n\n private getLatLng(value, type: 'lat' | 'lng') {\n return value\n ? value.split(',')[type == 'lat' ? 0 : 1]\n : '';\n }\n\n private getDisplayForType(option: Option) {\n if (this[`${option.type}Option`]) {\n return this[`${option.type}Option`](option);\n }\n\n if (option.type === DisplayType.COLOR_PICKER) {\n return this.colorPickerOption(option)\n }\n\n if (option.type === DisplayType.MULTIPLE_OPTIONS) {\n return this.multipleOptions(option);\n }\n\n if (option.type === DisplayType.SINGLE_OPTION) {\n return this.singleOption(option);\n }\n salla.log(`Couldn't find options type(${option.type})😢`);\n return '';\n }\n\n protected getOptionShownWhen(option: Option) {\n return option.visibility_condition\n ? { \"data-show-when\": `options[${option.visibility_condition.option}] ${option.visibility_condition.operator} ${option.visibility_condition.value}` }\n : {};\n }\n\n //we need the cart Id for productOption Image\n componentWillLoad() {\n this.outOfStockText = salla.lang.get('pages.products.out_of_stock')\n return salla.api.cart.getCurrentCartId();\n }\n\n componentDidRender() {\n if (this.optionsData?.length == 0 && !this.optionsData.some(option => option.type == DisplayType.DONATION)) {\n return;\n }\n let selectedDonationOption = this.optionsData.find(option => option.type == DisplayType.DONATION)?.details.find(detail => detail.is_selected);\n if (!selectedDonationOption) {\n return;\n }\n setTimeout(() => {\n salla.event.emit('product-options::donation-changed', {\n id: this.productId,\n price: selectedDonationOption.additional_price\n });\n }, 1000);\n }\n\n render() {\n if (this.optionsData?.length == 0) {\n return;\n }\n\n return (\n <Host class=\"s-product-options-wrapper\">\n {/* TODO:: move salla-conditional-field logic to here, no need of another component*/}\n <salla-conditional-fields>\n {this.optionsData.map((option: Option) =>\n <div class={`s-product-options-option-container${option.visibility_condition ? ' hidden' : ''}`}\n data-option-id={option.id}\n {...this.getOptionShownWhen(option)}>\n {option.name == 'splitter' ?\n this.splitterOption()\n : <div class=\"s-product-options-option\" data-option-type={option.type}\n data-option-required={`${option.required}`}>\n <label htmlFor={'options[' + option.id + ']'} class={`s-product-options-option-label ${this.hideLabel(option) ? 's-product-options-option-label-hidden' : ''}`}>\n <b>\n {option.name}\n {option.required && <span> * </span>} </b>\n <small>{option.placeholder}</small>\n </label>\n <div class={`s-product-options-option-content ${this.hideLabel(option) ? 's-product-options-option-content-full-width' : ''}`}>\n {this.getDisplayForType(option)}\n </div>\n </div>}\n </div>\n )}\n </salla-conditional-fields>\n </Host>\n );\n\n }\n\n //@ts-ignore\n private donationOption(option: Option, product: Product) {\n return <div class=\"s-product-options-donation-wrapper\">\n\n {option.donation?.can_donate ? [\n option.donation ?\n <div class=\"s-product-options-donation-progress\">\n <salla-progress-bar donation={option.donation}>\n </salla-progress-bar>\n </div>\n : '',\n option.details.length ?\n [<h4>{this.selectAmount}</h4>,\n <div class=\"s-product-options-donation-options\">\n {option.details.map((detail, i) =>\n <div class=\"s-product-options-donation-options-item\">\n <input id={`donation-option-${i}`} type=\"radio\" name=\"donating_option\" checked={detail.is_selected} value={detail.additional_price} onChange={e => this.handleDonationOptions(e, detail, 'option')} />\n <label htmlFor={`donation-option-${i}`}>\n <span>{salla.money(detail.name)}</span>\n </label>\n </div>\n )}\n {option.donation?.custom_amount_enabled ?\n <div class=\"s-product-options-donation-options-item\">\n <input id={`donation-option-custom`} type=\"radio\" name=\"donating_option\" value=\"custom\" onChange={e => this.handleDonationOptions(e, 'custom', 'option')} />\n <label htmlFor={`donation-option-custom`}>\n <span> {this.selectDonationAmount} </span>\n </label>\n </div>\n : ''\n }\n </div>] : '',\n\n <div class={{ \"s-product-options-donation-input-group\": true, \"shown\": !option.details.length || (option.details.length && this.isCustomDonation) }}>\n <input\n type=\"text\"\n id=\"donating-amount\"\n name=\"donation_amount\"\n class=\"s-form-control\"\n ref={el => this.donationInput = el as HTMLInputElement}\n value={\n option.details.length\n && option.details.some(detail => detail.is_selected)\n ? option.details.find(detail => detail.is_selected).additional_price\n : option.value}\n // required\n placeholder={option.placeholder}\n onInput={e => this.handleDonationOptions(e, 'custom', 'input')}\n onBlur={e => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n />\n {/* value={option.value} */}\n <span class=\"s-product-options-donation-amount-currency\">\n {salla.config.currency(salla.config.get('user.currency_code')).symbol}\n </span>\n </div>\n ] :\n this.getExpireDonationMessage(option)\n }\n </div>\n }\n\n private fileUploader(option: Option, additions: Object | null = null) {\n return <salla-file-upload\n {...(additions || {})}\n payload-name=\"file\"\n value={option.value}\n instant-upload={true}\n name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n height=\"120px\"\n onAdded={(e) => this.changedHandler(e, option)}\n url={salla.cart.api.getUploadImageEndpoint()}\n form-data={{ cart_item_id: this.productId, product_id: this.productId }}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n class={{ \"s-product-options-image-input\": true, required: option.required }}\n >\n <div class=\"s-product-options-filepond-placeholder\">\n <span class=\"s-product-options-filepond-placeholder-icon\"\n innerHTML={(additions as any).accept && (additions as any).accept.split(',').every(type => type.includes('image'))\n ? CameraIcon\n : FileIcon}\n />\n <p class=\"s-product-options-filepond-placeholder-text\">{salla.lang.get('common.uploader.drag_and_drop')}</p>\n <span class=\"filepond--label-action\">{salla.lang.get('common.uploader.browse')}</span>\n </div>\n </salla-file-upload>\n }\n\n //@ts-ignore\n private imageOption(option: Option) {\n return this.fileUploader(option, { accept: 'image/png,image/jpeg,image/jpg,image/gif' });\n }\n\n //@ts-ignore\n private fileOption(option: Option) {\n let types = option.details.map(detail => this.fileTypes[detail.name]).filter(Boolean);\n return types?.length\n ? this.fileUploader(option, { accept: types.join(',') })\n : 'File types not selected.';\n }\n\n // TODO: (ONLY FOR TESTING!) find a better way to make it testable, e.g. wrap it with a unique class like textOption\n //@ts-ignore\n private numberOption(option: Option) {\n return <input\n type=\"text\"\n value={option.value}\n class=\"s-form-control\"\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onBlur={e => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={e => salla.helpers.inputDigitsOnly(e.target)} />\n }\n\n //@ts-ignore\n private splitterOption() {\n return <div class=\"s-product-options-splitter\" />\n }\n\n //@ts-ignore\n private textOption(option: Option) {\n return <div class=\"s-product-options-text\">\n <input\n type=\"text\"\n value={option.value}\n class='s-form-control'\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={e => this.changedHandler(e, option)} />\n </div>\n }\n\n //@ts-ignore\n private textareaOption(option: Option) {\n //todo::remove mt-1 class, and if it's okay to remove the tag itself will be great\n return <div class=\"s-product-options-textarea\">\n <div class=\"mt-1\">\n <textarea\n rows={4}\n value={option.value}\n class=\"s-form-control\"\n required={!option.visibility_condition && option.required}\n id={`options[${option.id}]`}\n name={`options[${option.id}]`}\n placeholder={option.placeholder}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onInput={(e) => this.changedHandler(e, option)} />\n </div>\n </div>\n }\n\n //@ts-ignore\n private mapOption(option: Option) {\n return <salla-map\n zoom={15}\n lat={this.getLatLng(option.value, 'lat')}\n lng={this.getLatLng(option.value, 'lng')}\n name={`options[${option.id}]`}\n searchable={true}\n required={option.required}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onSelected={e => this.changedHandler(e, option)} />\n }\n\n private colorPickerOption(option: Option) {\n return <salla-color-picker\n onSubmitted={e => this.changedHandler(e, option)}\n name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n color={option.value} />\n }\n\n /**\n * ============= Date Time options =============\n */\n //@ts-ignore\n private timeOption(option: Option) {\n return <salla-datetime-picker\n noCalendar={true}\n enableTime={true}\n dateFormat=\"h:i K\"\n value={option.value}\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n class=\"s-product-options-time-element\"\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n }\n\n //@ts-ignore\n private dateOption(option: Option) {\n //todo:: consider date-range @see https://github.com/SallaApp/theme-raed/blob/master/src/assets/js/partials/product-options.js#L8-L23\n return <div class=\"s-product-options-date-element\">\n <salla-datetime-picker\n value={option.value}\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n minDate={new Date()}\n name={`options[${option.id}]`}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n </div>\n }\n\n //@ts-ignore\n private datetimeOption(option: Option) {\n //todo:: consider date-range @see https://github.com/SallaApp/theme-raed/blob/master/src/assets/js/partials/product-options.js#L8-L23\n return <div class=\"s-product-options-datetime-element\">\n <salla-datetime-picker\n enableTime={true}\n value={option.value}\n dateFormat=\"Y-m-d G:i:K\"\n placeholder={option.name}\n required={!option.visibility_condition && option.required}\n name={`options[${option.id}]`}\n maxDate={option.to_date_time}\n minDate={option.from_date_time}\n onInvalidInput={(e) => this.invalidHandler(e, option)}\n onPicked={e => this.changedHandler(e, option)} />\n </div>\n }\n\n /**\n * ============= Advanced options =============\n */\n protected getOptionDetailName(detail: Detail, outOfStock: boolean = true, optionType?: string) {\n if (optionType && optionType == DisplayType.COLOR) {\n return detail.name\n + ((outOfStock && this.isOptionDetailOut(detail)) ? ` <br/> <p> ${this.outOfStockText} </p>` : '')\n + (detail.additional_price ? ` <p> (${salla.money(detail.additional_price)}) </p>` : '');\n }\n\n return detail.name\n + ((outOfStock && this.isOptionDetailOut(detail)) ? ` - ${this.outOfStockText}` : '')\n + (detail.additional_price ? ` (${salla.money(detail.additional_price)})` : '');\n }\n\n\n protected isOptionDetailOut(detail: Detail) {\n if (detail.is_out || !detail.skus_availability || !this.selectedSkus?.length) {\n return detail.is_out;\n }\n\n let isDetailSelected = this.selectedOptions.filter(option => option.id == detail.id).length;\n //if the current options is the only selected option, so we are sure that it's not out, because there is no other options selected yet\n if (isDetailSelected && this.selectedOptions.length == 1) {\n return false;\n }\n\n //if current details has sku in the possible outSkus it's out for sure\n if (isDetailSelected) {\n //here we will get the possible outSkus for current selected options\n let outSelectableSkus = this.selectedSkus.filter(sku => this.outSkus.includes(sku));\n return Object.keys(detail.skus_availability).some(sku => outSelectableSkus.includes(Number(sku)))\n }\n\n return this.selectedOptions.some(option => option.is_out && option.option_id !== detail.option_id)\n\n }\n\n private singleOption(option: Option) {\n return <div>\n <select name={`options[${option.id}]`}\n required={!option.visibility_condition && option.required}\n class=\"s-form-control\"\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={e => this.changedHandler(e, option)}>\n <option value=\"\">{option.placeholder}</option>\n {\n option?.details.map((detail: Detail) => {\n return <option value={detail.id} disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n selected={detail.is_selected}>\n {this.getOptionDetailName(detail)}\n </option>\n })\n }\n </select>\n </div>\n }\n\n private multipleOptions(option: Option) {\n let is_required = option.required && !option.details.some(detail => detail.is_selected) && !option.visibility_condition;\n return <div class={{ \"s-product-options-multiple-options-wrapper\": true, 'required': option.required }}>\n {\n option?.details.map((detail: Detail) => {\n return <div>\n <input type=\"checkbox\"\n value={detail.id}\n disabled={this.isOptionDetailOut(detail)}\n checked={detail.is_selected}\n required={is_required}\n name={`options[${option.id}][]`}\n id={`field-${option.id}-${detail.id}`}\n onChange={(e) => this.changedHandler(e, option)}\n onInvalid={(e) => this.invalidHandler(e, option)}\n aria-describedby={`options[${option.id}]-description`} />\n <label htmlFor={`field-${option.id}-${detail.id}`}>{this.getOptionDetailName(detail)}</label>\n </div>\n })\n }\n </div>\n }\n\n //@ts-ignore\n private colorOption(option: Option) {\n return <fieldset class=\"s-product-options-colors-wrapper\">\n {\n option?.details.map((detail) =>\n <div class=\"s-product-options-colors-item\">\n <input type=\"radio\"\n value={detail.id}\n required={!option.visibility_condition && option.required}\n checked={detail.is_selected}\n name={`options[${option.id}]`}\n disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n id={`color-${this.productId}-${option.id}-${detail.id}`}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={e => this.changedHandler(e, option)} />\n <label htmlFor={`color-${this.productId}-${option.id}-${detail.id}`}>\n <span style={{ \"background-color\": detail.color }} />\n <div innerHTML={this.getOptionDetailName(detail, true, option.type)}></div>\n </label>\n </div>\n )\n }\n </fieldset>\n }\n\n //@ts-ignore\n private thumbnailOption(option: Option) {\n return <div class=\"s-product-options-thumbnails-wrapper\">\n {option.details.map((detail: Detail) => {\n return <div>\n <input type=\"radio\"\n value={detail.id}\n data-itemid={detail.id} //todo:: why need this? it's already in the value!\n required={!option.visibility_condition && option.required}\n checked={detail.is_selected}\n name={`options[${option.id}]`}\n data-img-id={detail.option_value}\n disabled={this.canDisabled && this.isOptionDetailOut(detail)}\n id={`option_${this.productId}-${option.id}_${detail.id}`}\n onInvalid={(e) => this.invalidHandler(e, option)}\n onChange={(e) => this.changedHandler(e, option)} />\n <label htmlFor={`option_${this.productId}-${option.id}_${detail.id}`}\n data-img-id={detail.option_value}\n class=\"go-to-slide\">\n <img data-src={detail.image} src={detail.image} title={detail.name} alt={detail.name} />\n <span innerHTML={CheckCircleIcon} class=\"s-product-options-thumbnails-icon\" />\n {this.isOptionDetailOut(detail) ?\n [\n <small class=\"s-product-options-thumbnails-stock-badge\">{this.outOfStockText}</small>,\n this.canDisabled ? <div class=\"s-product-options-thumbnails-badge-overlay\" /> : '',\n ]\n : ''}\n </label>\n <p>{this.getOptionDetailName(detail, false)} </p>\n </div>\n })}\n </div>\n }\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
1
  var __awaiter=this&&this.__awaiter||function(e,t,r,i){function n(e){return e instanceof r?e:new r((function(t){t(e)}))}return new(r||(r=Promise))((function(r,o){function a(e){try{l(i.next(e))}catch(e){o(e)}}function s(e){try{l(i["throw"](e))}catch(e){o(e)}}function l(e){e.done?r(e.value):n(e.value).then(a,s)}l((i=i.apply(e,t||[])).next())}))};var __generator=this&&this.__generator||function(e,t){var r={label:0,sent:function(){if(o[0]&1)throw o[1];return o[1]},trys:[],ops:[]},i,n,o,a;return a={next:s(0),throw:s(1),return:s(2)},typeof Symbol==="function"&&(a[Symbol.iterator]=function(){return this}),a;function s(e){return function(t){return l([e,t])}}function l(s){if(i)throw new TypeError("Generator is already executing.");while(a&&(a=0,s[0]&&(r=0)),r)try{if(i=1,n&&(o=s[0]&2?n["return"]:s[0]?n["throw"]||((o=n["return"])&&o.call(n),0):n.next)&&!(o=o.call(n,s[1])).done)return o;if(n=0,o)s=[s[0]&2,o.value];switch(s[0]){case 0:case 1:o=s;break;case 4:r.label++;return{value:s[1],done:false};case 5:r.label++;n=s[1];s=[0];continue;case 7:s=r.ops.pop();r.trys.pop();continue;default:if(!(o=r.trys,o=o.length>0&&o[o.length-1])&&(s[0]===6||s[0]===2)){r=0;continue}if(s[0]===3&&(!o||s[1]>o[0]&&s[1]<o[3])){r.label=s[1];break}if(s[0]===6&&r.label<o[1]){r.label=o[1];o=s;break}if(o&&r.label<o[2]){r.label=o[2];r.ops.push(s);break}if(o[2])r.ops.pop();r.trys.pop();continue}s=t.call(e,r)}catch(e){s=[6,e];n=0}finally{i=o=0}if(s[0]&5)throw s[1];return{value:s[0]?s[1]:void 0,done:true}}};
2
2
  /*!
3
3
  * Crafted with ❤ by Salla
4
- */import{r as registerInstance,c as createEvent,h,H as Host,g as getElement}from"./index-e6c3f002.js";import{a as anime}from"./anime.es-6b92d9cd.js";import{H as Helper}from"./Helper-17531428.js";var ShoppingBag='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>shopping-bag</title>\n<path d="M28 10.667h-4v-2.667c0-4.412-3.588-8-8-8s-8 3.588-8 8v2.667h-4c-0.736 0-1.333 0.596-1.333 1.333v13.333c0 3.676 2.991 6.667 6.667 6.667h13.333c3.676 0 6.667-2.991 6.667-6.667v-13.333c0-0.737-0.597-1.333-1.333-1.333zM10.667 8c0-2.941 2.392-5.333 5.333-5.333s5.333 2.392 5.333 5.333v2.667h-10.667zM26.667 25.333c0 2.205-1.795 4-4 4h-13.333c-2.205 0-4-1.795-4-4v-12h2.667v2.667c0 0.737 0.597 1.333 1.333 1.333s1.333-0.596 1.333-1.333v-2.667h10.667v2.667c0 0.737 0.597 1.333 1.333 1.333s1.333-0.596 1.333-1.333v-2.667h2.667z"></path>\n</svg>\n';var sallaProductsListCss="";var SallaProductsList=function(){function e(e){var t=this;registerInstance(this,e);this.productsFetched=createEvent(this,"productsFetched",7);this.source=undefined;this.sourceValue=undefined;this.limit=undefined;this.sortBy=undefined;this.filtersResults=undefined;this.horizontalCards=undefined;this.autoload=false;this.loadMoreText=undefined;this.productCardComponent="custom-salla-product-card";this.page=1;this.nextPage=undefined;this.hasInfiniteScroll=undefined;this.hasCustomComponent=undefined;this.sourceValueIsValid=undefined;this.placeholderText=salla.lang.get("pages.categories.no_products");this.endOfText=salla.lang.get("common.elements.end_of_content");this.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more");this.currentPage=salla.config.get("page");this.currentCategoryIdFilter=undefined;this.isReady=undefined;this.showPlaceholder=undefined;this.parsedFilters=undefined;salla.lang.onLoaded((function(){t.placeholderText=salla.lang.get("pages.categories.no_products");t.endOfText=salla.lang.get("common.elements.end_of_content");t.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more")}))}e.prototype.connectedCallback=function(){var e=this;salla.event.on("salla-filters::changed",(function(t){return e.setFilters(t)}))};e.prototype.setFilters=function(e){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(t){if(!e||JSON.stringify(e)===JSON.stringify(this.parsedFilters)){return[2]}window.scrollTo({top:0,behavior:"smooth"});this.parsedFilters=JSON.parse(JSON.stringify(e));if(this.currentPage.slug=="product.index"&&this.parsedFilters&&this.parsedFilters.category_id){this.currentCategoryIdFilter=[this.parsedFilters.category_id]}return[2,this.reload()]}))}))};e.prototype.reload=function(){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(e){!this.autoload&&this.loadMoreWrapper&&(this.loadMoreWrapper.style.display="none");this.hasInfiniteScroll&&salla.infiniteScroll.destroy(this.infiniteScroll);this.buildNextPageUrl();this.wrapper.innerHTML="";if(this.hasInfiniteScroll){this.init()}else{this.getInitialData()}if(this.showPlaceholder){this.showPlaceholder=false;this.placeholderLoader=document.createElement("div");this.placeholderLoader.classList.add("s-products-list-loading-wrapper");this.placeholderLoader.style.display="inherit";this.placeholderLoader.innerHTML='<span class="s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"></span>';this.host.insertAdjacentElement("afterend",this.placeholderLoader)}return[2]}))}))};e.prototype.isFilterable=function(){return salla.config.get("store.settings.product.filters")&&this.filtersResults};e.prototype.isSourceWithoutValue=function(){return["offers","latest","sales"].includes(this.getSource())};e.prototype.animateItems=function(){anime({targets:"salla-products-list salla-product-card",opacity:[0,1],duration:1200,translateY:[20,0],delay:function(e,t){return t*100}})};e.prototype.initBaseNextPageUrl=function(e){var t=this;this.nextPage=salla.url.api("products?source=".concat(e));if(this.limit){this.nextPage+="&per_page=".concat(this.limit>32?32:this.limit)}if(this.sortBy){this.nextPage+="&sort=".concat(this.sortBy)}this.nextPage+="&filterable=1";var r=function(e,r){if(["string","number"].includes(typeof r)){i.nextPage+="&filters[".concat(encodeURIComponent(e),"]=").concat(encodeURIComponent(r))}else if(Array.isArray(r)){r.forEach((function(r){return t.nextPage+="&filters[".concat(encodeURIComponent(e),"][]=").concat(encodeURIComponent(r))}))}else if(typeof r==="object"){for(var n=0,o=Object.entries(r);n<o.length;n++){var a=o[n],s=a[0],l=a[1];i.nextPage+="&filters[".concat(encodeURIComponent(e),"][").concat(encodeURIComponent(s),"]=").concat(encodeURIComponent(l))}}};var i=this;for(var n=0,o=Object.entries(this.parsedFilters||{});n<o.length;n++){var a=o[n],s=a[0],l=a[1];r(s,l)}};e.prototype.buildNextPageUrl=function(){var e=this.getSource();if(e==="json"){return}this.initBaseNextPageUrl(e);if(this.isSourceWithoutValue()){return}if(["search","related","landing-page"].includes(e)){this.nextPage+="&source_value=".concat(this.getSourceValue());return}try{this.nextPage+="&source_value[]=".concat(this.getSourceValue().join("&source_value[]="))}catch(t){salla.logger.warn('source-value prop should be array of ids ex source-value="[1,2,3]" for the source ['.concat(e,"]"));this.sourceValueIsValid=false}};e.prototype.loading=function(e,t){if(e===void 0){e=true}if(t===void 0){t=false}if(!e){if(!this.autoload){this.btnLoader&&(this.btnLoader.style.display="none")}this.loader&&(this.loader.style.display="none")}else{var r=t&&!this.autoload?this.btnLoader:this.loader;r&&(r.style.display="inherit")}};e.prototype.getItemHTML=function(e){this.getSource()==="landing-page"&&(e.url="");var t=this.hasCustomComponent?this.productCardComponent:"salla-product-card";var r=document.createElement(t);r.product=e;this.applyLandingPageStyles(r);this.applyHorizontalCardStyles(r);return r};e.prototype.applyLandingPageStyles=function(e){if(this.getSource()==="landing-page"&&!this.hasCustomComponent){e.toggleAttribute("hide-add-btn",true);e.classList.add("s-product-card-fit-height")}};e.prototype.applyHorizontalCardStyles=function(e){if(!this.horizontalCards){return}e.setAttribute("horizontal",true);if(!this.hasCustomComponent){e.setAttribute("shadow-on-hover",true)}};e.prototype.getSource=function(){return Helper.getProductsSource(this.source)};e.prototype.getSourceValue=function(){return this.currentCategoryIdFilter?this.currentCategoryIdFilter:Helper.getProductsSourceValue(this.source,this.sourceValue)};e.prototype.appendDataLayer=function(e){if(typeof dataLayer!=="object"||!Array.isArray(dataLayer)){return}dataLayer.push({event:"impressions",ecommerce:{currencyCode:salla.config.currency().code,impressions:e.map((function(e,t){var r,i,n;return{id:e.id,name:e.name,price:e.price,brand:((r=e.brand)===null||r===void 0?void 0:r.name)||"",quantity:e.quantity,categories:[{name:((i=e.category)===null||i===void 0?void 0:i.name)||salla.config.get("page.title"),id:salla.config.get("page.id")}],category:((n=e.category)===null||n===void 0?void 0:n.name)||salla.config.get("page.title"),position:t+1}}))}})};e.prototype.initiateInfiniteScroll=function(){var e=this;var t,r,i;if(!this.hasInfiniteScroll){return}this.infiniteScroll=salla.infiniteScroll.initiate(this.wrapper,this.wrapper,{path:function(){return e.nextPage},history:false,nextPage:this.nextPage,scrollThreshold:this.autoload?100:false,loadOnScroll:this.autoload},true);(t=this.infiniteScroll)===null||t===void 0?void 0:t.on("request",(function(){e.loading(true,e.autoload?false:true)}));(r=this.infiniteScroll)===null||r===void 0?void 0:r.on("load",(function(t){var r;if(!((r=t.data)===null||r===void 0?void 0:r.length)&&e.infiniteScroll.pageIndex==2){e.showPlaceholder=true;salla.infiniteScroll.destroy(e.infiniteScroll);e.loading(false);e.placeholderLoader&&e.placeholderLoader.remove();return}else{e.showPlaceholder=false}e.infiniteScroll.appendItems(e.handleResponse(t));if(e.infiniteScroll.pageIndex==2){if(!e.autoload&&e.nextPage){e.loadMoreWrapper.style.display="block"}e.animateItems()}}));(i=this.infiniteScroll)===null||i===void 0?void 0:i.on("error",(function(){e.status.querySelector(".s-infinite-scroll-error").classList.remove("s-hidden");e.placeholderLoader&&e.placeholderLoader.remove();e.loading(false)}));salla.onReady((function(){return salla.infiniteScroll.loadNextPage(e.infiniteScroll)}))};e.prototype.getInitialData=function(){var e=this;this.loading();return Helper.fetchProducts(this.getSource(),this.getSourceValue(),this.limit).then((function(t){if(!t.data.length){e.showPlaceholder=true;e.placeholderLoader&&e.placeholderLoader.remove();e.loading(false);return}if(!e.firstPageResponse){e.firstPageResponse=t;e.nextPage=t.cursor?t.cursor.next:e.nextPage;return}e.handleResponse(t).forEach((function(t){return e.wrapper.append(t)}))}))};e.prototype.loadMore=function(){return __awaiter(this,void 0,void 0,(function(){var e;return __generator(this,(function(t){(e=this.infiniteScroll)===null||e===void 0?void 0:e.loadNextPage();return[2]}))}))};e.prototype.componentWillLoad=function(){var e=this;return Helper.onSallaReadyPromise((function(t){e.hasCustomComponent=!!customElements.get(e.productCardComponent);e.sourceValueIsValid=!!(e.getSourceValue()||e.isSourceWithoutValue());e.hasInfiniteScroll=!["json","selected","related","landing-page"].includes(e.getSource())&&!e.limit;var r=new URLSearchParams(window.location.search);try{e.sortBy=e.sortBy||r.get("sort")||r.get("by");e.parsedFilters=Helper.extractFiltersFromUrl(r);if(e.parsedFilters&&e.parsedFilters.category_id){e.currentCategoryIdFilter=[e.parsedFilters.category_id]}}catch(e){salla.logger.warn("failed to get filters from url",e.message)}e.buildNextPageUrl();e.isReady=true;if(!e.sourceValueIsValid){salla.logger.warn("source-value prop is required for source [".concat(e.getSource(),"]"));return t()}if(e.hasInfiniteScroll){return t()}if(e.getSource()==="json"){if(!e.getSourceValue().length){e.showPlaceholder=true;return t()}setTimeout((function(){var t=e.getSourceValue();t.map((function(t){return e.wrapper.append(e.getItemHTML(t))}))}));return t()}if(e.getSource()==="selected"&&!e.getSourceValue().length){e.showPlaceholder=true;return t()}return e.getInitialData().then((function(){return t(true)}))}))};e.prototype.canRender=function(){return this.sourceValueIsValid&&this.isReady};e.prototype.render=function(){var e=this;if(!this.canRender()){return""}if(this.showPlaceholder){return h("div",{class:"s-products-list-placeholder"},h("span",{innerHTML:ShoppingBag}),h("p",null,this.placeholderText))}return h(Host,{class:"s-products-list"},h("div",{class:{"s-products-list-wrapper":true,"s-products-list-horizontal-cards":this.horizontalCards&&!this.filtersResults,"s-products-list-vertical-cards":!this.horizontalCards&&!this.filtersResults,"s-products-list-filters-results":this.filtersResults},ref:function(t){return e.wrapper=t}}),h("div",{class:"s-infinite-scroll-status",ref:function(t){return e.status=t}},h("p",{class:"s-infinite-scroll-last infinite-scroll-last s-hidden"},this.endOfText),h("p",{class:"s-infinite-scroll-error infinite-scroll-error s-hidden"},this.failedLoadMore)),h("div",{class:"s-products-list-loading-wrapper",style:{display:"none"},ref:function(t){return e.loader=t}},h("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"})),this.hasInfiniteScroll&&this.nextPage&&!this.autoload?h("div",{class:"s-infinite-scroll-wrapper",style:{display:"none"},ref:function(t){return e.loadMoreWrapper=t}},h("button",{onClick:function(){return e.loadMore()},class:"s-infinite-scroll-btn s-button-btn s-button-primary"},h("span",{class:"s-button-text s-infinite-scroll-btn-text"},this.loadMoreText?this.loadMoreText:salla.lang.get("common.elements.load_more")),h("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader",ref:function(t){return e.btnLoader=t},style:{display:"none"}}))):"")};e.prototype.componentDidLoad=function(){var e=this;this.hasInfiniteScroll&&this.init();this.firstPageResponse&&this.handleResponse(this.firstPageResponse,false).forEach((function(t){return e.wrapper.append(t)}))};e.prototype.init=function(){this.initiateInfiniteScroll();this.loading()};e.prototype.handleResponse=function(e,t){var r=this;if(t===void 0){t=true}var i,n,o,a,s,l;if(!e){return[]}var c=this.getSource();var u="";if(((i=e.cursor)===null||i===void 0?void 0:i.current)===1){u=Helper.getPageTitleForSource(c);try{if(this.getSource()==="search"){u=salla.lang.get("common.elements.search_about",{word:this.getSourceValue()})}else if(!u){var d=this.parsedFilters.category_id||this.getSourceValue()[0];u=((a=(o=(n=e.filters.find((function(e){return e.key=="category_id"})))===null||n===void 0?void 0:n.values)===null||o===void 0?void 0:o.find((function(e){return e.key==d})))===null||a===void 0?void 0:a.value)||""}u+=(u?" - ":"")+salla.lang.choice("blocks.header.products_count",(s=e.data)===null||s===void 0?void 0:s.length);if(e.data.length===15){u=u.replace(e.data.length,salla.lang.get("common.elements.more_than")+" "+e.data.length)}e.title=u}catch(e){}Helper.generateProductSchema(e.data)}this.appendDataLayer(e.data);salla.event.emit("salla-products-list::products.fetched",e);this.productsFetched.emit(e);if(e.filters&&this.isFilterable()){this.filtersResults=true;salla.event.emit("filters::fetched",{filters:e.filters})}else if(this.isFilterable()){salla.event.emit("filters::hidden")}if(t){this.nextPage=e.cursor?e.cursor.next:this.nextPage}this.loading(false);this.placeholderLoader&&this.placeholderLoader.remove();if(this.hasInfiniteScroll&&!this.nextPage){this.infiniteScroll.option({scrollThreshold:false,loadOnScroll:false});this.status.querySelector(".s-infinite-scroll-last").classList.remove("s-hidden")}return((l=e.data)===null||l===void 0?void 0:l.map((function(e){return r.getItemHTML(e)})))||[]};Object.defineProperty(e.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return e}();SallaProductsList.style=sallaProductsListCss;export{SallaProductsList as salla_products_list};
4
+ */import{r as registerInstance,c as createEvent,h,H as Host,g as getElement}from"./index-9a9b1e67.js";import{a as anime}from"./anime.es-6b92d9cd.js";import{H as Helper}from"./Helper-17531428.js";var ShoppingBag='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>shopping-bag</title>\n<path d="M28 10.667h-4v-2.667c0-4.412-3.588-8-8-8s-8 3.588-8 8v2.667h-4c-0.736 0-1.333 0.596-1.333 1.333v13.333c0 3.676 2.991 6.667 6.667 6.667h13.333c3.676 0 6.667-2.991 6.667-6.667v-13.333c0-0.737-0.597-1.333-1.333-1.333zM10.667 8c0-2.941 2.392-5.333 5.333-5.333s5.333 2.392 5.333 5.333v2.667h-10.667zM26.667 25.333c0 2.205-1.795 4-4 4h-13.333c-2.205 0-4-1.795-4-4v-12h2.667v2.667c0 0.737 0.597 1.333 1.333 1.333s1.333-0.596 1.333-1.333v-2.667h10.667v2.667c0 0.737 0.597 1.333 1.333 1.333s1.333-0.596 1.333-1.333v-2.667h2.667z"></path>\n</svg>\n';var sallaProductsListCss="";var SallaProductsList=function(){function e(e){var t=this;registerInstance(this,e);this.productsFetched=createEvent(this,"productsFetched",7);this.source=undefined;this.sourceValue=undefined;this.limit=undefined;this.sortBy=undefined;this.filtersResults=undefined;this.horizontalCards=undefined;this.autoload=false;this.loadMoreText=undefined;this.productCardComponent="custom-salla-product-card";this.page=1;this.nextPage=undefined;this.hasInfiniteScroll=undefined;this.hasCustomComponent=undefined;this.sourceValueIsValid=undefined;this.placeholderText=salla.lang.get("pages.categories.no_products");this.endOfText=salla.lang.get("common.elements.end_of_content");this.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more");this.currentPage=salla.config.get("page");this.currentCategoryIdFilter=undefined;this.isReady=undefined;this.showPlaceholder=undefined;this.parsedFilters=undefined;salla.lang.onLoaded((function(){t.placeholderText=salla.lang.get("pages.categories.no_products");t.endOfText=salla.lang.get("common.elements.end_of_content");t.failedLoadMore=salla.lang.get("common.elements.failed_to_load_more")}))}e.prototype.connectedCallback=function(){var e=this;salla.event.on("salla-filters::changed",(function(t){return e.setFilters(t)}))};e.prototype.setFilters=function(e){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(t){if(!e||JSON.stringify(e)===JSON.stringify(this.parsedFilters)){return[2]}window.scrollTo({top:0,behavior:"smooth"});this.parsedFilters=JSON.parse(JSON.stringify(e));if(this.currentPage.slug=="product.index"&&this.parsedFilters&&this.parsedFilters.category_id){this.currentCategoryIdFilter=[this.parsedFilters.category_id]}return[2,this.reload()]}))}))};e.prototype.reload=function(){return __awaiter(this,void 0,void 0,(function(){return __generator(this,(function(e){!this.autoload&&this.loadMoreWrapper&&(this.loadMoreWrapper.style.display="none");this.hasInfiniteScroll&&salla.infiniteScroll.destroy(this.infiniteScroll);this.buildNextPageUrl();this.wrapper.innerHTML="";if(this.hasInfiniteScroll){this.init()}else{this.getInitialData()}if(this.showPlaceholder){this.showPlaceholder=false;this.placeholderLoader=document.createElement("div");this.placeholderLoader.classList.add("s-products-list-loading-wrapper");this.placeholderLoader.style.display="inherit";this.placeholderLoader.innerHTML='<span class="s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"></span>';this.host.insertAdjacentElement("afterend",this.placeholderLoader)}return[2]}))}))};e.prototype.isFilterable=function(){return salla.config.get("store.settings.product.filters")&&this.filtersResults};e.prototype.isSourceWithoutValue=function(){return["offers","latest","sales"].includes(this.getSource())};e.prototype.animateItems=function(){anime({targets:"salla-products-list salla-product-card",opacity:[0,1],duration:1200,translateY:[20,0],delay:function(e,t){return t*100}})};e.prototype.initBaseNextPageUrl=function(e){var t=this;this.nextPage=salla.url.api("products?source=".concat(e));if(this.limit){this.nextPage+="&per_page=".concat(this.limit>32?32:this.limit)}if(this.sortBy){this.nextPage+="&sort=".concat(this.sortBy)}this.nextPage+="&filterable=1";var r=function(e,r){if(["string","number"].includes(typeof r)){i.nextPage+="&filters[".concat(encodeURIComponent(e),"]=").concat(encodeURIComponent(r))}else if(Array.isArray(r)){r.forEach((function(r){return t.nextPage+="&filters[".concat(encodeURIComponent(e),"][]=").concat(encodeURIComponent(r))}))}else if(typeof r==="object"){for(var n=0,o=Object.entries(r);n<o.length;n++){var a=o[n],s=a[0],l=a[1];i.nextPage+="&filters[".concat(encodeURIComponent(e),"][").concat(encodeURIComponent(s),"]=").concat(encodeURIComponent(l))}}};var i=this;for(var n=0,o=Object.entries(this.parsedFilters||{});n<o.length;n++){var a=o[n],s=a[0],l=a[1];r(s,l)}};e.prototype.buildNextPageUrl=function(){var e=this.getSource();if(e==="json"){return}this.initBaseNextPageUrl(e);if(this.isSourceWithoutValue()){return}if(["search","related","landing-page"].includes(e)){this.nextPage+="&source_value=".concat(this.getSourceValue());return}try{this.nextPage+="&source_value[]=".concat(this.getSourceValue().join("&source_value[]="))}catch(t){salla.logger.warn('source-value prop should be array of ids ex source-value="[1,2,3]" for the source ['.concat(e,"]"));this.sourceValueIsValid=false}};e.prototype.loading=function(e,t){if(e===void 0){e=true}if(t===void 0){t=false}if(!e){if(!this.autoload){this.btnLoader&&(this.btnLoader.style.display="none")}this.loader&&(this.loader.style.display="none")}else{var r=t&&!this.autoload?this.btnLoader:this.loader;r&&(r.style.display="inherit")}};e.prototype.getItemHTML=function(e){this.getSource()==="landing-page"&&(e.url="");var t=this.hasCustomComponent?this.productCardComponent:"salla-product-card";var r=document.createElement(t);r.product=e;this.applyLandingPageStyles(r);this.applyHorizontalCardStyles(r);return r};e.prototype.applyLandingPageStyles=function(e){if(this.getSource()==="landing-page"&&!this.hasCustomComponent){e.toggleAttribute("hide-add-btn",true);e.classList.add("s-product-card-fit-height")}};e.prototype.applyHorizontalCardStyles=function(e){if(!this.horizontalCards){return}e.setAttribute("horizontal",true);if(!this.hasCustomComponent){e.setAttribute("shadow-on-hover",true)}};e.prototype.getSource=function(){return Helper.getProductsSource(this.source)};e.prototype.getSourceValue=function(){return this.currentCategoryIdFilter?this.currentCategoryIdFilter:Helper.getProductsSourceValue(this.source,this.sourceValue)};e.prototype.appendDataLayer=function(e){if(typeof dataLayer!=="object"||!Array.isArray(dataLayer)){return}dataLayer.push({event:"impressions",ecommerce:{currencyCode:salla.config.currency().code,impressions:e.map((function(e,t){var r,i,n;return{id:e.id,name:e.name,price:e.price,brand:((r=e.brand)===null||r===void 0?void 0:r.name)||"",quantity:e.quantity,categories:[{name:((i=e.category)===null||i===void 0?void 0:i.name)||salla.config.get("page.title"),id:salla.config.get("page.id")}],category:((n=e.category)===null||n===void 0?void 0:n.name)||salla.config.get("page.title"),position:t+1}}))}})};e.prototype.initiateInfiniteScroll=function(){var e=this;var t,r,i;if(!this.hasInfiniteScroll){return}this.infiniteScroll=salla.infiniteScroll.initiate(this.wrapper,this.wrapper,{path:function(){return e.nextPage},history:false,nextPage:this.nextPage,scrollThreshold:this.autoload?100:false,loadOnScroll:this.autoload},true);(t=this.infiniteScroll)===null||t===void 0?void 0:t.on("request",(function(){e.loading(true,e.autoload?false:true)}));(r=this.infiniteScroll)===null||r===void 0?void 0:r.on("load",(function(t){var r;if(!((r=t.data)===null||r===void 0?void 0:r.length)&&e.infiniteScroll.pageIndex==2){e.showPlaceholder=true;salla.infiniteScroll.destroy(e.infiniteScroll);e.loading(false);e.placeholderLoader&&e.placeholderLoader.remove();return}else{e.showPlaceholder=false}e.infiniteScroll.appendItems(e.handleResponse(t));if(e.infiniteScroll.pageIndex==2){if(!e.autoload&&e.nextPage){e.loadMoreWrapper.style.display="block"}e.animateItems()}}));(i=this.infiniteScroll)===null||i===void 0?void 0:i.on("error",(function(){e.status.querySelector(".s-infinite-scroll-error").classList.remove("s-hidden");e.placeholderLoader&&e.placeholderLoader.remove();e.loading(false)}));salla.onReady((function(){return salla.infiniteScroll.loadNextPage(e.infiniteScroll)}))};e.prototype.getInitialData=function(){var e=this;this.loading();return Helper.fetchProducts(this.getSource(),this.getSourceValue(),this.limit).then((function(t){if(!t.data.length){e.showPlaceholder=true;e.placeholderLoader&&e.placeholderLoader.remove();e.loading(false);return}if(!e.firstPageResponse){e.firstPageResponse=t;e.nextPage=t.cursor?t.cursor.next:e.nextPage;return}e.handleResponse(t).forEach((function(t){return e.wrapper.append(t)}))}))};e.prototype.loadMore=function(){return __awaiter(this,void 0,void 0,(function(){var e;return __generator(this,(function(t){(e=this.infiniteScroll)===null||e===void 0?void 0:e.loadNextPage();return[2]}))}))};e.prototype.componentWillLoad=function(){var e=this;return Helper.onSallaReadyPromise((function(t){e.hasCustomComponent=!!customElements.get(e.productCardComponent);e.sourceValueIsValid=!!(e.getSourceValue()||e.isSourceWithoutValue());e.hasInfiniteScroll=!["json","selected","related","landing-page"].includes(e.getSource())&&!e.limit;var r=new URLSearchParams(window.location.search);try{e.sortBy=e.sortBy||r.get("sort")||r.get("by");e.parsedFilters=Helper.extractFiltersFromUrl(r);if(e.parsedFilters&&e.parsedFilters.category_id){e.currentCategoryIdFilter=[e.parsedFilters.category_id]}}catch(e){salla.logger.warn("failed to get filters from url",e.message)}e.buildNextPageUrl();e.isReady=true;if(!e.sourceValueIsValid){salla.logger.warn("source-value prop is required for source [".concat(e.getSource(),"]"));return t()}if(e.hasInfiniteScroll){return t()}if(e.getSource()==="json"){if(!e.getSourceValue().length){e.showPlaceholder=true;return t()}setTimeout((function(){var t=e.getSourceValue();t.map((function(t){return e.wrapper.append(e.getItemHTML(t))}))}));return t()}if(e.getSource()==="selected"&&!e.getSourceValue().length){e.showPlaceholder=true;return t()}return e.getInitialData().then((function(){return t(true)}))}))};e.prototype.canRender=function(){return this.sourceValueIsValid&&this.isReady};e.prototype.render=function(){var e=this;if(!this.canRender()){return""}if(this.showPlaceholder){return h("div",{class:"s-products-list-placeholder"},h("span",{innerHTML:ShoppingBag}),h("p",null,this.placeholderText))}return h(Host,{class:"s-products-list"},h("div",{class:{"s-products-list-wrapper":true,"s-products-list-horizontal-cards":this.horizontalCards&&!this.filtersResults,"s-products-list-vertical-cards":!this.horizontalCards&&!this.filtersResults,"s-products-list-filters-results":this.filtersResults},ref:function(t){return e.wrapper=t}}),h("div",{class:"s-infinite-scroll-status",ref:function(t){return e.status=t}},h("p",{class:"s-infinite-scroll-last infinite-scroll-last s-hidden"},this.endOfText),h("p",{class:"s-infinite-scroll-error infinite-scroll-error s-hidden"},this.failedLoadMore)),h("div",{class:"s-products-list-loading-wrapper",style:{display:"none"},ref:function(t){return e.loader=t}},h("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader"})),this.hasInfiniteScroll&&this.nextPage&&!this.autoload?h("div",{class:"s-infinite-scroll-wrapper",style:{display:"none"},ref:function(t){return e.loadMoreWrapper=t}},h("button",{onClick:function(){return e.loadMore()},class:"s-infinite-scroll-btn s-button-btn s-button-primary"},h("span",{class:"s-button-text s-infinite-scroll-btn-text"},this.loadMoreText?this.loadMoreText:salla.lang.get("common.elements.load_more")),h("span",{class:"s-button-loader s-button-loader-center s-infinite-scroll-btn-loader",ref:function(t){return e.btnLoader=t},style:{display:"none"}}))):"")};e.prototype.componentDidLoad=function(){var e=this;this.hasInfiniteScroll&&this.init();this.firstPageResponse&&this.handleResponse(this.firstPageResponse,false).forEach((function(t){return e.wrapper.append(t)}))};e.prototype.init=function(){this.initiateInfiniteScroll();this.loading()};e.prototype.handleResponse=function(e,t){var r=this;if(t===void 0){t=true}var i,n,o,a,s,l;if(!e){return[]}var c=this.getSource();var u="";if(((i=e.cursor)===null||i===void 0?void 0:i.current)===1){u=Helper.getPageTitleForSource(c);try{if(this.getSource()==="search"){u=salla.lang.get("common.elements.search_about",{word:this.getSourceValue()})}else if(!u){var d=this.parsedFilters.category_id||this.getSourceValue()[0];u=((a=(o=(n=e.filters.find((function(e){return e.key=="category_id"})))===null||n===void 0?void 0:n.values)===null||o===void 0?void 0:o.find((function(e){return e.key==d})))===null||a===void 0?void 0:a.value)||""}u+=(u?" - ":"")+salla.lang.choice("blocks.header.products_count",(s=e.data)===null||s===void 0?void 0:s.length);if(e.data.length===15){u=u.replace(e.data.length,salla.lang.get("common.elements.more_than")+" "+e.data.length)}e.title=u}catch(e){}Helper.generateProductSchema(e.data)}this.appendDataLayer(e.data);salla.event.emit("salla-products-list::products.fetched",e);this.productsFetched.emit(e);if(e.filters&&this.isFilterable()){this.filtersResults=true;salla.event.emit("filters::fetched",{filters:e.filters})}else if(this.isFilterable()){salla.event.emit("filters::hidden")}if(t){this.nextPage=e.cursor?e.cursor.next:this.nextPage}this.loading(false);this.placeholderLoader&&this.placeholderLoader.remove();if(this.hasInfiniteScroll&&!this.nextPage){this.infiniteScroll.option({scrollThreshold:false,loadOnScroll:false});this.status.querySelector(".s-infinite-scroll-last").classList.remove("s-hidden")}return((l=e.data)===null||l===void 0?void 0:l.map((function(e){return r.getItemHTML(e)})))||[]};Object.defineProperty(e.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return e}();SallaProductsList.style=sallaProductsListCss;export{SallaProductsList as salla_products_list};
5
5
  //# sourceMappingURL=salla-products-list.entry.js.map
@@ -1,5 +1,5 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
4
- import{r as registerInstance,h,H as Host,g as getElement}from"./index-e6c3f002.js";import{H as Helper}from"./Helper-17531428.js";var sallaProductsSliderCss="";var SallaProductsSlider=function(){function e(e){registerInstance(this,e);this.blockTitle=undefined;this.subTitle=undefined;this.sliderId=undefined;this.displayAllUrl=undefined;this.autoplay=undefined;this.source=undefined;this.sourceValue=undefined;this.limit=undefined;this.sliderConfig=undefined;this.productCardComponent="custom-salla-product-card";this.productsData=undefined;this.isReady=undefined;this.sourceValueIsValid=undefined;this.hasCustomComponent=undefined;this.apiUrl="";this.parsedSourceValue=undefined}e.prototype.componentWillLoad=function(){var e=this;return Helper.onSallaReadyPromise((function(t){e.sourceValueIsValid=!!(e.getSourceValue()||e.isSourceWithoutValue());if(!e.sourceValueIsValid){salla.logger.warn("source-value prop is required for source [".concat(e.getSource(),"]"));return t(true)}e.hasCustomComponent=!!customElements.get(e.productCardComponent);if(e.source==="json"){e.productsData=e.getSourceValue();e.isReady=true;return t(true)}if(e.getSource()=="related"&&!salla.config.get("store.settings.product.related_products_enabled")){e.isReady=false;return t(true)}return Helper.fetchProducts(e.getSource(),e.getSourceValue(),e.limit).then((function(r){e.productsData=r.data;e.isReady=true;salla.event.emit("salla-products-slider::products.fetched",r.data);t(r)}))}))};e.prototype.isSourceWithoutValue=function(){return["offers","latest","sales"].includes(this.getSource())};e.prototype.getItemHTML=function(e){this.getSource()==="landing-page"&&(e.url="");if(this.hasCustomComponent&&this.productCardComponent.toLowerCase()=="custom-salla-product-card"){return h("div",{class:"s-products-slider-card"},h("custom-salla-product-card",{product:e,source:this.getSource(),"source-value":this.getSourceValue()}))}if(this.hasCustomComponent){var t=document.createElement(this.productCardComponent);t.setAttribute("product",JSON.stringify(e));t.setAttribute("source",this.getSource());t.setAttribute("source-value",this.getSourceValue());return h("div",{class:"s-products-slider-card",innerHTML:t.outerHTML})}return h("div",{class:"s-products-slider-card"},h("salla-product-card",{"show-quantity":this.getSource()=="landing-page","hide-add-btn":this.getSource()=="landing-page","shadow-on-hover":true,product:e}))};e.prototype.canRender=function(){return this.sourceValueIsValid&&this.isReady};e.prototype.getSource=function(){return Helper.getProductsSource(this.source)};e.prototype.getSourceValue=function(){return Helper.getProductsSourceValue(this.source,this.sourceValue)};e.prototype.render=function(){var e=this;var t;if(!this.canRender()){return}return h(Host,{class:"s-products-slider-wrapper"},h("salla-slider",{class:"s-products-slider-slider",id:this.sliderId||"s-products-slider-".concat(Math.random().toString(36).substr(2,9)),"auto-play":this.autoplay,type:"carousel","block-title":this.blockTitle,"block-subTitle":this.subTitle,"display-all-url":this.displayAllUrl,sliderConfig:this.sliderConfig?this.sliderConfig:null},h("div",{slot:"items"},(t=this.productsData)===null||t===void 0?void 0:t.map((function(t){return e.getItemHTML(t)})))))};Object.defineProperty(e.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return e}();SallaProductsSlider.style=sallaProductsSliderCss;export{SallaProductsSlider as salla_products_slider};
4
+ import{r as registerInstance,h,H as Host,g as getElement}from"./index-9a9b1e67.js";import{H as Helper}from"./Helper-17531428.js";var sallaProductsSliderCss="";var SallaProductsSlider=function(){function e(e){registerInstance(this,e);this.blockTitle=undefined;this.subTitle=undefined;this.sliderId=undefined;this.displayAllUrl=undefined;this.autoplay=undefined;this.source=undefined;this.sourceValue=undefined;this.limit=undefined;this.sliderConfig=undefined;this.productCardComponent="custom-salla-product-card";this.productsData=undefined;this.isReady=undefined;this.sourceValueIsValid=undefined;this.hasCustomComponent=undefined;this.apiUrl="";this.parsedSourceValue=undefined}e.prototype.componentWillLoad=function(){var e=this;return Helper.onSallaReadyPromise((function(t){e.sourceValueIsValid=!!(e.getSourceValue()||e.isSourceWithoutValue());if(!e.sourceValueIsValid){salla.logger.warn("source-value prop is required for source [".concat(e.getSource(),"]"));return t(true)}e.hasCustomComponent=!!customElements.get(e.productCardComponent);if(e.source==="json"){e.productsData=e.getSourceValue();e.isReady=true;return t(true)}if(e.getSource()=="related"&&!salla.config.get("store.settings.product.related_products_enabled")){e.isReady=false;return t(true)}return Helper.fetchProducts(e.getSource(),e.getSourceValue(),e.limit).then((function(r){e.productsData=r.data;e.isReady=true;salla.event.emit("salla-products-slider::products.fetched",r.data);t(r)}))}))};e.prototype.isSourceWithoutValue=function(){return["offers","latest","sales"].includes(this.getSource())};e.prototype.getItemHTML=function(e){this.getSource()==="landing-page"&&(e.url="");if(this.hasCustomComponent&&this.productCardComponent.toLowerCase()=="custom-salla-product-card"){return h("div",{class:"s-products-slider-card"},h("custom-salla-product-card",{product:e,source:this.getSource(),"source-value":this.getSourceValue()}))}if(this.hasCustomComponent){var t=document.createElement(this.productCardComponent);t.setAttribute("product",JSON.stringify(e));t.setAttribute("source",this.getSource());t.setAttribute("source-value",this.getSourceValue());return h("div",{class:"s-products-slider-card",innerHTML:t.outerHTML})}return h("div",{class:"s-products-slider-card"},h("salla-product-card",{"show-quantity":this.getSource()=="landing-page","hide-add-btn":this.getSource()=="landing-page","shadow-on-hover":true,product:e}))};e.prototype.canRender=function(){return this.sourceValueIsValid&&this.isReady};e.prototype.getSource=function(){return Helper.getProductsSource(this.source)};e.prototype.getSourceValue=function(){return Helper.getProductsSourceValue(this.source,this.sourceValue)};e.prototype.render=function(){var e=this;var t;if(!this.canRender()){return}return h(Host,{class:"s-products-slider-wrapper"},h("salla-slider",{class:"s-products-slider-slider",id:this.sliderId||"s-products-slider-".concat(Math.random().toString(36).substr(2,9)),"auto-play":this.autoplay,type:"carousel","block-title":this.blockTitle,"block-subTitle":this.subTitle,"display-all-url":this.displayAllUrl,sliderConfig:this.sliderConfig?this.sliderConfig:null},h("div",{slot:"items"},(t=this.productsData)===null||t===void 0?void 0:t.map((function(t){return e.getItemHTML(t)})))))};Object.defineProperty(e.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return e}();SallaProductsSlider.style=sallaProductsSliderCss;export{SallaProductsSlider as salla_products_slider};
5
5
  //# sourceMappingURL=salla-products-slider.entry.js.map
@@ -1,5 +1,5 @@
1
1
  /*!
2
2
  * Crafted with ❤ by Salla
3
3
  */
4
- import{r as registerInstance,h,H as Host,g as getElement}from"./index-e6c3f002.js";import{t as twitter,f as facebook}from"./twitter-4aa505e4.js";var instagram='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>instagram</title>\n<path d="M23 32h-14c-4.971 0-9-4.029-9-9v0-14c0-4.971 4.029-9 9-9v0h14c4.971 0 9 4.029 9 9v0 14c0 4.971-4.029 9-9 9v0zM9 2c-3.866 0-7 3.134-7 7v0 14c0 3.866 3.134 7 7 7v0h14c3.866 0 7-3.134 7-7v0-14c0-3.866-3.134-7-7-7v0zM16 24c-4.418 0-8-3.582-8-8s3.582-8 8-8c4.418 0 8 3.582 8 8v0c0 4.418-3.582 8-8 8v0zM16 10c-3.314 0-6 2.686-6 6s2.686 6 6 6c3.314 0 6-2.686 6-6v0c0-3.314-2.686-6-6-6v0zM25 9c-1.105 0-2-0.895-2-2s0.895-2 2-2c1.105 0 2 0.895 2 2v0c0 1.105-0.895 2-2 2v0zM25 7v0z"></path>\n</svg>\n';var youtube='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>youtube</title>\n<path d="M16 28c-3.666 0-8.376-0.056-10.29-0.162-0.113 0.010-0.244 0.016-0.376 0.016-1.676 0-3.139-0.91-3.922-2.264l-0.012-0.022c-0.97-1.6-1.4-4.248-1.4-8.558s0.436-6.962 1.412-8.6c0.782-1.36 2.227-2.262 3.883-2.262 0.148 0 0.293 0.007 0.437 0.021l-0.018-0.001c1.872-0.124 6.544-0.168 10.286-0.168s8.4 0.044 10.292 0.168c0.124-0.012 0.267-0.019 0.412-0.019 1.656 0 3.101 0.905 3.866 2.247l0.012 0.022c0.982 1.624 1.418 4.27 1.418 8.582 0 4.338-0.438 6.982-1.422 8.6-0.789 1.364-2.241 2.268-3.904 2.268-0.133 0-0.265-0.006-0.395-0.017l0.017 0.001c-1.926 0.092-6.632 0.148-10.296 0.148zM16 8c-3.712 0-8.334 0.042-10.168 0.164-1.688 0.094-2.14 0.306-2.702 1.268-0.756 1.81-1.195 3.913-1.195 6.119 0 0.51 0.024 1.015 0.069 1.513l-0.005-0.064c-0.042 0.435-0.065 0.941-0.065 1.453 0 2.198 0.438 4.294 1.231 6.205l-0.039-0.107c0.566 0.968 1.022 1.184 2.708 1.296 3.29 0.184 17.022 0.184 20.34 0 1.678-0.11 2.132-0.326 2.684-1.28 0.764-1.803 1.208-3.899 1.208-6.1 0-0.513-0.024-1.020-0.071-1.52l0.005 0.064c0.042-0.436 0.065-0.943 0.065-1.455 0-2.203-0.439-4.303-1.235-6.218l0.040 0.107v-0.016c-0.554-0.958-1-1.17-2.684-1.264-1.862-0.122-6.644-0.164-10.186-0.164zM13 23c-0.552 0-1-0.448-1-1v0-10c0 0 0 0 0 0 0-0.552 0.448-1 1-1 0.196 0 0.38 0.057 0.534 0.154l-0.004-0.002 8 5c0.284 0.18 0.47 0.492 0.47 0.848s-0.186 0.668-0.466 0.846l-0.004 0.002-8 5c-0.15 0.095-0.334 0.152-0.53 0.152 0 0 0 0 0 0v0zM14 13.8v6.4l5.114-3.2z"></path>\n</svg>\n';var snapchat='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>snapchat</title>\n<path d="M16.186 30h-0.266c-1.843-0.023-3.525-0.693-4.834-1.792l0.012 0.010c-0.476-0.405-1.043-0.72-1.665-0.909l-0.033-0.009c-0.287-0.044-0.617-0.069-0.954-0.069-0.492 0-0.972 0.053-1.434 0.155l0.044-0.008c-0.261 0.061-0.564 0.102-0.875 0.114l-0.009 0c-0.017 0.001-0.036 0.001-0.056 0.001-0.811 0-1.495-0.545-1.705-1.288l-0.003-0.012c-0.076-0.26-0.132-0.506-0.186-0.746-0.961-0.157-1.822-0.412-2.633-0.76l0.073 0.028c-0.667-0.259-1.199-0.745-1.509-1.362l-0.007-0.016c-0.082-0.189-0.135-0.409-0.146-0.64l-0-0.004c-0.002-0.031-0.003-0.067-0.003-0.103 0-0.841 0.614-1.538 1.417-1.668l0.010-0.001c0.822-0.141 1.555-0.438 2.198-0.859l-0.022 0.013c0.611-0.405 1.138-0.872 1.591-1.404l0.009-0.010c0.526-0.595 0.98-1.273 1.337-2.007l0.023-0.053c0.060-0.102 0.107-0.22 0.135-0.346l0.001-0.008c-0.092-0.020-0.73-0.222-0.972-0.298s-0.374-0.12-0.506-0.17c-0.546-0.205-1.016-0.487-1.424-0.839l0.006 0.005c-0.471-0.388-0.768-0.971-0.768-1.624 0-0.126 0.011-0.249 0.032-0.369l-0.002 0.013c0.143-0.644 0.551-1.172 1.1-1.474l0.011-0.006c0.389-0.241 0.861-0.384 1.366-0.384 0.347 0 0.678 0.067 0.982 0.19l-0.018-0.006c0.128 0.060 0.242 0.106 0.344 0.142-0.082-0.573-0.129-1.235-0.129-1.908 0-1.482 0.227-2.91 0.648-4.253l-0.027 0.101c0.512-1.142 1.207-2.114 2.056-2.925l0.004-0.003c0.7-0.664 1.516-1.214 2.413-1.616l0.055-0.022c1.128-0.5 2.444-0.794 3.828-0.8h0.592c1.386 0.007 2.701 0.301 3.893 0.825l-0.063-0.025c0.956 0.42 1.777 0.967 2.485 1.632l-0.005-0.004c0.855 0.815 1.55 1.789 2.039 2.876l0.023 0.058c0.396 1.237 0.625 2.659 0.625 4.135 0 0.658-0.045 1.304-0.133 1.938l0.008-0.073 0.172-0.076c0.303-0.16 0.661-0.253 1.042-0.253 0.374 0 0.728 0.091 1.039 0.251l-0.013-0.006c0.886 0.274 1.528 1.063 1.582 2.008l0 0.006c-0.001 0.602-0.25 1.146-0.65 1.536l-0 0c-0.429 0.408-0.945 0.73-1.516 0.935l-0.030 0.009c-0.144 0.056-0.316 0.112-0.504 0.17-0.367 0.103-0.686 0.235-0.984 0.398l0.024-0.012c0.018 0.030 0.042 0.094 0.086 0.18 0.963 2.174 2.834 3.796 5.118 4.4l0.054 0.012c0.814 0.133 1.427 0.83 1.427 1.671 0 0.036-0.001 0.072-0.003 0.108l0-0.005c-0.012 0.241-0.070 0.465-0.165 0.669l0.005-0.011c-0.319 0.624-0.847 1.103-1.489 1.352l-0.019 0.006c-0.739 0.323-1.6 0.578-2.497 0.724l-0.063 0.008c-0.056 0.264-0.112 0.496-0.186 0.742-0.215 0.747-0.893 1.284-1.696 1.284-0.011 0-0.021-0-0.032-0l0.002 0c-0.328-0.004-0.644-0.042-0.949-0.11l0.031 0.006c-0.404-0.090-0.869-0.142-1.345-0.142-0.353 0-0.7 0.029-1.038 0.083l0.037-0.005c-0.653 0.195-1.218 0.508-1.699 0.917l0.007-0.005c-1.275 1.065-2.916 1.731-4.71 1.788l-0.012 0zM8.444 25.218c0.457 0.001 0.904 0.041 1.339 0.117l-0.047-0.007c0.966 0.232 1.808 0.664 2.516 1.252l-0.010-0.008c0.96 0.829 2.199 1.357 3.56 1.427l0.014 0.001h0.37c1.373-0.070 2.61-0.597 3.576-1.43l-0.008 0.006c0.701-0.583 1.546-1.016 2.474-1.239l0.042-0.009c0.394-0.063 0.849-0.1 1.312-0.1 0.615 0 1.216 0.064 1.795 0.186l-0.057-0.010c0.105 0.023 0.238 0.045 0.372 0.059l0.016 0.001c0.042-0.162 0.076-0.314 0.11-0.47 0.059-0.339 0.156-0.641 0.287-0.924l-0.009 0.023 0.234-0.44 0.492-0.078c0.99-0.119 1.892-0.359 2.738-0.705l-0.070 0.025c0.086-0.040 0.158-0.076 0.216-0.11-2.748-0.86-4.933-2.816-6.081-5.342l-0.025-0.062c-0.184-0.31-0.294-0.684-0.294-1.083 0-0.27 0.050-0.528 0.14-0.765l-0.005 0.015c0.492-0.783 1.284-1.339 2.212-1.507l0.020-0.003c0.14-0.044 0.27-0.084 0.376-0.126 0.327-0.108 0.609-0.272 0.849-0.482l-0.003 0.002c0.074-0.106 0-0.2-0.216-0.284-0.094-0.041-0.203-0.065-0.318-0.066h-0c-0.529 0.242-1.142 0.411-1.786 0.474l-0.024 0.002c-0.313-0-0.612-0.064-0.883-0.18l0.015 0.006-0.628-0.28 0.072-1.272c0.093-0.623 0.146-1.342 0.146-2.074 0-1.269-0.16-2.501-0.46-3.677l0.022 0.103c-0.396-0.896-0.936-1.659-1.598-2.296l-0.002-0.002c-0.541-0.508-1.172-0.928-1.865-1.233l-0.043-0.017c-0.895-0.396-1.939-0.629-3.036-0.634h-0.002l-0.218-1v1h-0.348c-1.105 0.003-2.155 0.237-3.106 0.656l0.050-0.020c-0.733 0.322-1.361 0.742-1.903 1.253l0.003-0.003c-0.663 0.638-1.203 1.398-1.582 2.247l-0.018 0.045c-0.279 1.065-0.44 2.287-0.44 3.547 0 0.704 0.050 1.395 0.147 2.072l-0.009-0.078 0.080 1.372-0.618 0.284c-0.31 0.108-0.666 0.17-1.038 0.17-0.6 0-1.163-0.163-1.645-0.446l0.015 0.008c-0.019-0.001-0.041-0.002-0.064-0.002-0.154 0-0.299 0.039-0.425 0.109l0.005-0.002c-0.063 0.032-0.115 0.078-0.153 0.135l-0.001 0.001c0.258 0.244 0.567 0.435 0.91 0.556l0.018 0.006c0.094 0.036 0.2 0.070 0.32 0.108 0.971 0.167 1.784 0.732 2.282 1.516l0.008 0.014c0.087 0.225 0.137 0.486 0.137 0.758 0 0.403-0.11 0.781-0.303 1.104l0.005-0.010c-0.459 0.983-1.016 1.829-1.677 2.582l0.011-0.012c-0.588 0.687-1.26 1.279-2.004 1.768l-0.036 0.022c-0.689 0.451-1.49 0.805-2.346 1.017l-0.054 0.011c0.060 0.034 0.132 0.072 0.218 0.112 0.776 0.322 1.678 0.561 2.618 0.675l0.050 0.005 0.498 0.078 0.234 0.446c0.116 0.255 0.209 0.553 0.265 0.863l0.003 0.023c0.038 0.164 0.072 0.328 0.118 0.496 0.12-0.014 0.242-0.042 0.378-0.068 0.528-0.12 1.138-0.192 1.762-0.2l0.006-0zM30.244 22.892v0z"></path>\n</svg>\n';var tiktok='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>tiktok</title>\n<path d="M29.046 7.029c-3.359 0-6.092-2.733-6.092-6.092 0-0.518-0.42-0.938-0.938-0.938h-5.021c-0.518 0-0.938 0.42-0.938 0.938v20.585c0 1.975-1.606 3.581-3.581 3.581s-3.581-1.606-3.581-3.581c0-1.975 1.606-3.581 3.581-3.581 0.518 0 0.938-0.42 0.938-0.938v-5.021c0-0.518-0.42-0.938-0.938-0.938-5.777 0-10.477 4.7-10.477 10.477s4.7 10.477 10.477 10.477c5.777 0 10.477-4.7 10.477-10.477v-9.112c1.866 0.995 3.942 1.514 6.092 1.514 0.518 0 0.938-0.42 0.938-0.938v-5.021c0-0.518-0.42-0.938-0.938-0.938zM28.108 12.011c-2.001-0.166-3.902-0.866-5.544-2.047-0.285-0.206-0.662-0.234-0.975-0.073s-0.51 0.482-0.51 0.834v10.798c0 4.743-3.859 8.602-8.602 8.602s-8.602-3.859-8.602-8.602c0-4.427 3.361-8.083 7.665-8.552v3.176c-2.563 0.446-4.519 2.687-4.519 5.376 0 3.009 2.447 5.456 5.456 5.456s5.456-2.448 5.456-5.456v-19.648h3.201c0.429 3.645 3.329 6.545 6.974 6.974z"></path>\n</svg>\n';var sallaSocialCss=":host{display:block}";var SallaSocial=function(){function c(c){var l=this;registerInstance(this,c);var t;this.links=salla.config.get("store.social");this.iconsList={instagram:instagram,twitter:twitter,facebook:facebook,youtube:youtube,snapchat:snapchat,tiktok:tiktok};this.socialSlot=((t=this.host.querySelector('[slot="social"]'))===null||t===void 0?void 0:t.innerHTML)||'<li class="s-social-link"><a href={link} rel="noopener" target="_blank" title={type} aria-label={type}><span class="s-social-icon">{icon}</span></a></li>';salla.lang.onLoaded((function(){l.links=salla.config.get("store.social")}))}c.prototype.getLinksArray=function(){return Object.entries(this.links).filter((function(c){var l=c[0],t=c[1];return!!t&&l!=="whatsapp"})).map((function(c){var l=c[0],t=c[1];return{type:l,value:t}}))};c.prototype.render=function(){var c=this;var l=this.getLinksArray();return h(Host,{class:"s-social-list"},l.map((function(l){return h("div",{id:"social-slot",innerHTML:c.socialSlot.replace(/\{icon\}/g,c.iconsList[l.type]).replace(/\{type\}/g,l.type).replace(/\{link\}/g,l.value.toString())})})))};c.prototype.componentDidRender=function(){var c;this.host.querySelectorAll("#social-slot").forEach((function(c){return c.replaceWith(c.firstChild)}));(c=this.host.querySelector('[slot="social"]'))===null||c===void 0?void 0:c.remove()};Object.defineProperty(c.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return c}();SallaSocial.style=sallaSocialCss;export{SallaSocial as salla_social};
4
+ import{r as registerInstance,h,H as Host,g as getElement}from"./index-9a9b1e67.js";import{t as twitter,f as facebook}from"./twitter-4aa505e4.js";var instagram='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>instagram</title>\n<path d="M23 32h-14c-4.971 0-9-4.029-9-9v0-14c0-4.971 4.029-9 9-9v0h14c4.971 0 9 4.029 9 9v0 14c0 4.971-4.029 9-9 9v0zM9 2c-3.866 0-7 3.134-7 7v0 14c0 3.866 3.134 7 7 7v0h14c3.866 0 7-3.134 7-7v0-14c0-3.866-3.134-7-7-7v0zM16 24c-4.418 0-8-3.582-8-8s3.582-8 8-8c4.418 0 8 3.582 8 8v0c0 4.418-3.582 8-8 8v0zM16 10c-3.314 0-6 2.686-6 6s2.686 6 6 6c3.314 0 6-2.686 6-6v0c0-3.314-2.686-6-6-6v0zM25 9c-1.105 0-2-0.895-2-2s0.895-2 2-2c1.105 0 2 0.895 2 2v0c0 1.105-0.895 2-2 2v0zM25 7v0z"></path>\n</svg>\n';var youtube='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>youtube</title>\n<path d="M16 28c-3.666 0-8.376-0.056-10.29-0.162-0.113 0.010-0.244 0.016-0.376 0.016-1.676 0-3.139-0.91-3.922-2.264l-0.012-0.022c-0.97-1.6-1.4-4.248-1.4-8.558s0.436-6.962 1.412-8.6c0.782-1.36 2.227-2.262 3.883-2.262 0.148 0 0.293 0.007 0.437 0.021l-0.018-0.001c1.872-0.124 6.544-0.168 10.286-0.168s8.4 0.044 10.292 0.168c0.124-0.012 0.267-0.019 0.412-0.019 1.656 0 3.101 0.905 3.866 2.247l0.012 0.022c0.982 1.624 1.418 4.27 1.418 8.582 0 4.338-0.438 6.982-1.422 8.6-0.789 1.364-2.241 2.268-3.904 2.268-0.133 0-0.265-0.006-0.395-0.017l0.017 0.001c-1.926 0.092-6.632 0.148-10.296 0.148zM16 8c-3.712 0-8.334 0.042-10.168 0.164-1.688 0.094-2.14 0.306-2.702 1.268-0.756 1.81-1.195 3.913-1.195 6.119 0 0.51 0.024 1.015 0.069 1.513l-0.005-0.064c-0.042 0.435-0.065 0.941-0.065 1.453 0 2.198 0.438 4.294 1.231 6.205l-0.039-0.107c0.566 0.968 1.022 1.184 2.708 1.296 3.29 0.184 17.022 0.184 20.34 0 1.678-0.11 2.132-0.326 2.684-1.28 0.764-1.803 1.208-3.899 1.208-6.1 0-0.513-0.024-1.020-0.071-1.52l0.005 0.064c0.042-0.436 0.065-0.943 0.065-1.455 0-2.203-0.439-4.303-1.235-6.218l0.040 0.107v-0.016c-0.554-0.958-1-1.17-2.684-1.264-1.862-0.122-6.644-0.164-10.186-0.164zM13 23c-0.552 0-1-0.448-1-1v0-10c0 0 0 0 0 0 0-0.552 0.448-1 1-1 0.196 0 0.38 0.057 0.534 0.154l-0.004-0.002 8 5c0.284 0.18 0.47 0.492 0.47 0.848s-0.186 0.668-0.466 0.846l-0.004 0.002-8 5c-0.15 0.095-0.334 0.152-0.53 0.152 0 0 0 0 0 0v0zM14 13.8v6.4l5.114-3.2z"></path>\n</svg>\n';var snapchat='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>snapchat</title>\n<path d="M16.186 30h-0.266c-1.843-0.023-3.525-0.693-4.834-1.792l0.012 0.010c-0.476-0.405-1.043-0.72-1.665-0.909l-0.033-0.009c-0.287-0.044-0.617-0.069-0.954-0.069-0.492 0-0.972 0.053-1.434 0.155l0.044-0.008c-0.261 0.061-0.564 0.102-0.875 0.114l-0.009 0c-0.017 0.001-0.036 0.001-0.056 0.001-0.811 0-1.495-0.545-1.705-1.288l-0.003-0.012c-0.076-0.26-0.132-0.506-0.186-0.746-0.961-0.157-1.822-0.412-2.633-0.76l0.073 0.028c-0.667-0.259-1.199-0.745-1.509-1.362l-0.007-0.016c-0.082-0.189-0.135-0.409-0.146-0.64l-0-0.004c-0.002-0.031-0.003-0.067-0.003-0.103 0-0.841 0.614-1.538 1.417-1.668l0.010-0.001c0.822-0.141 1.555-0.438 2.198-0.859l-0.022 0.013c0.611-0.405 1.138-0.872 1.591-1.404l0.009-0.010c0.526-0.595 0.98-1.273 1.337-2.007l0.023-0.053c0.060-0.102 0.107-0.22 0.135-0.346l0.001-0.008c-0.092-0.020-0.73-0.222-0.972-0.298s-0.374-0.12-0.506-0.17c-0.546-0.205-1.016-0.487-1.424-0.839l0.006 0.005c-0.471-0.388-0.768-0.971-0.768-1.624 0-0.126 0.011-0.249 0.032-0.369l-0.002 0.013c0.143-0.644 0.551-1.172 1.1-1.474l0.011-0.006c0.389-0.241 0.861-0.384 1.366-0.384 0.347 0 0.678 0.067 0.982 0.19l-0.018-0.006c0.128 0.060 0.242 0.106 0.344 0.142-0.082-0.573-0.129-1.235-0.129-1.908 0-1.482 0.227-2.91 0.648-4.253l-0.027 0.101c0.512-1.142 1.207-2.114 2.056-2.925l0.004-0.003c0.7-0.664 1.516-1.214 2.413-1.616l0.055-0.022c1.128-0.5 2.444-0.794 3.828-0.8h0.592c1.386 0.007 2.701 0.301 3.893 0.825l-0.063-0.025c0.956 0.42 1.777 0.967 2.485 1.632l-0.005-0.004c0.855 0.815 1.55 1.789 2.039 2.876l0.023 0.058c0.396 1.237 0.625 2.659 0.625 4.135 0 0.658-0.045 1.304-0.133 1.938l0.008-0.073 0.172-0.076c0.303-0.16 0.661-0.253 1.042-0.253 0.374 0 0.728 0.091 1.039 0.251l-0.013-0.006c0.886 0.274 1.528 1.063 1.582 2.008l0 0.006c-0.001 0.602-0.25 1.146-0.65 1.536l-0 0c-0.429 0.408-0.945 0.73-1.516 0.935l-0.030 0.009c-0.144 0.056-0.316 0.112-0.504 0.17-0.367 0.103-0.686 0.235-0.984 0.398l0.024-0.012c0.018 0.030 0.042 0.094 0.086 0.18 0.963 2.174 2.834 3.796 5.118 4.4l0.054 0.012c0.814 0.133 1.427 0.83 1.427 1.671 0 0.036-0.001 0.072-0.003 0.108l0-0.005c-0.012 0.241-0.070 0.465-0.165 0.669l0.005-0.011c-0.319 0.624-0.847 1.103-1.489 1.352l-0.019 0.006c-0.739 0.323-1.6 0.578-2.497 0.724l-0.063 0.008c-0.056 0.264-0.112 0.496-0.186 0.742-0.215 0.747-0.893 1.284-1.696 1.284-0.011 0-0.021-0-0.032-0l0.002 0c-0.328-0.004-0.644-0.042-0.949-0.11l0.031 0.006c-0.404-0.090-0.869-0.142-1.345-0.142-0.353 0-0.7 0.029-1.038 0.083l0.037-0.005c-0.653 0.195-1.218 0.508-1.699 0.917l0.007-0.005c-1.275 1.065-2.916 1.731-4.71 1.788l-0.012 0zM8.444 25.218c0.457 0.001 0.904 0.041 1.339 0.117l-0.047-0.007c0.966 0.232 1.808 0.664 2.516 1.252l-0.010-0.008c0.96 0.829 2.199 1.357 3.56 1.427l0.014 0.001h0.37c1.373-0.070 2.61-0.597 3.576-1.43l-0.008 0.006c0.701-0.583 1.546-1.016 2.474-1.239l0.042-0.009c0.394-0.063 0.849-0.1 1.312-0.1 0.615 0 1.216 0.064 1.795 0.186l-0.057-0.010c0.105 0.023 0.238 0.045 0.372 0.059l0.016 0.001c0.042-0.162 0.076-0.314 0.11-0.47 0.059-0.339 0.156-0.641 0.287-0.924l-0.009 0.023 0.234-0.44 0.492-0.078c0.99-0.119 1.892-0.359 2.738-0.705l-0.070 0.025c0.086-0.040 0.158-0.076 0.216-0.11-2.748-0.86-4.933-2.816-6.081-5.342l-0.025-0.062c-0.184-0.31-0.294-0.684-0.294-1.083 0-0.27 0.050-0.528 0.14-0.765l-0.005 0.015c0.492-0.783 1.284-1.339 2.212-1.507l0.020-0.003c0.14-0.044 0.27-0.084 0.376-0.126 0.327-0.108 0.609-0.272 0.849-0.482l-0.003 0.002c0.074-0.106 0-0.2-0.216-0.284-0.094-0.041-0.203-0.065-0.318-0.066h-0c-0.529 0.242-1.142 0.411-1.786 0.474l-0.024 0.002c-0.313-0-0.612-0.064-0.883-0.18l0.015 0.006-0.628-0.28 0.072-1.272c0.093-0.623 0.146-1.342 0.146-2.074 0-1.269-0.16-2.501-0.46-3.677l0.022 0.103c-0.396-0.896-0.936-1.659-1.598-2.296l-0.002-0.002c-0.541-0.508-1.172-0.928-1.865-1.233l-0.043-0.017c-0.895-0.396-1.939-0.629-3.036-0.634h-0.002l-0.218-1v1h-0.348c-1.105 0.003-2.155 0.237-3.106 0.656l0.050-0.020c-0.733 0.322-1.361 0.742-1.903 1.253l0.003-0.003c-0.663 0.638-1.203 1.398-1.582 2.247l-0.018 0.045c-0.279 1.065-0.44 2.287-0.44 3.547 0 0.704 0.050 1.395 0.147 2.072l-0.009-0.078 0.080 1.372-0.618 0.284c-0.31 0.108-0.666 0.17-1.038 0.17-0.6 0-1.163-0.163-1.645-0.446l0.015 0.008c-0.019-0.001-0.041-0.002-0.064-0.002-0.154 0-0.299 0.039-0.425 0.109l0.005-0.002c-0.063 0.032-0.115 0.078-0.153 0.135l-0.001 0.001c0.258 0.244 0.567 0.435 0.91 0.556l0.018 0.006c0.094 0.036 0.2 0.070 0.32 0.108 0.971 0.167 1.784 0.732 2.282 1.516l0.008 0.014c0.087 0.225 0.137 0.486 0.137 0.758 0 0.403-0.11 0.781-0.303 1.104l0.005-0.010c-0.459 0.983-1.016 1.829-1.677 2.582l0.011-0.012c-0.588 0.687-1.26 1.279-2.004 1.768l-0.036 0.022c-0.689 0.451-1.49 0.805-2.346 1.017l-0.054 0.011c0.060 0.034 0.132 0.072 0.218 0.112 0.776 0.322 1.678 0.561 2.618 0.675l0.050 0.005 0.498 0.078 0.234 0.446c0.116 0.255 0.209 0.553 0.265 0.863l0.003 0.023c0.038 0.164 0.072 0.328 0.118 0.496 0.12-0.014 0.242-0.042 0.378-0.068 0.528-0.12 1.138-0.192 1.762-0.2l0.006-0zM30.244 22.892v0z"></path>\n</svg>\n';var tiktok='\x3c!-- Generated by IcoMoon.io --\x3e\n<svg version="1.1" xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32">\n<title>tiktok</title>\n<path d="M29.046 7.029c-3.359 0-6.092-2.733-6.092-6.092 0-0.518-0.42-0.938-0.938-0.938h-5.021c-0.518 0-0.938 0.42-0.938 0.938v20.585c0 1.975-1.606 3.581-3.581 3.581s-3.581-1.606-3.581-3.581c0-1.975 1.606-3.581 3.581-3.581 0.518 0 0.938-0.42 0.938-0.938v-5.021c0-0.518-0.42-0.938-0.938-0.938-5.777 0-10.477 4.7-10.477 10.477s4.7 10.477 10.477 10.477c5.777 0 10.477-4.7 10.477-10.477v-9.112c1.866 0.995 3.942 1.514 6.092 1.514 0.518 0 0.938-0.42 0.938-0.938v-5.021c0-0.518-0.42-0.938-0.938-0.938zM28.108 12.011c-2.001-0.166-3.902-0.866-5.544-2.047-0.285-0.206-0.662-0.234-0.975-0.073s-0.51 0.482-0.51 0.834v10.798c0 4.743-3.859 8.602-8.602 8.602s-8.602-3.859-8.602-8.602c0-4.427 3.361-8.083 7.665-8.552v3.176c-2.563 0.446-4.519 2.687-4.519 5.376 0 3.009 2.447 5.456 5.456 5.456s5.456-2.448 5.456-5.456v-19.648h3.201c0.429 3.645 3.329 6.545 6.974 6.974z"></path>\n</svg>\n';var sallaSocialCss=":host{display:block}";var SallaSocial=function(){function c(c){var l=this;registerInstance(this,c);var t;this.links=salla.config.get("store.social");this.iconsList={instagram:instagram,twitter:twitter,facebook:facebook,youtube:youtube,snapchat:snapchat,tiktok:tiktok};this.socialSlot=((t=this.host.querySelector('[slot="social"]'))===null||t===void 0?void 0:t.innerHTML)||'<li class="s-social-link"><a href={link} rel="noopener" target="_blank" title={type} aria-label={type}><span class="s-social-icon">{icon}</span></a></li>';salla.lang.onLoaded((function(){l.links=salla.config.get("store.social")}))}c.prototype.getLinksArray=function(){return Object.entries(this.links).filter((function(c){var l=c[0],t=c[1];return!!t&&l!=="whatsapp"})).map((function(c){var l=c[0],t=c[1];return{type:l,value:t}}))};c.prototype.render=function(){var c=this;var l=this.getLinksArray();return h(Host,{class:"s-social-list"},l.map((function(l){return h("div",{id:"social-slot",innerHTML:c.socialSlot.replace(/\{icon\}/g,c.iconsList[l.type]).replace(/\{type\}/g,l.type).replace(/\{link\}/g,l.value.toString())})})))};c.prototype.componentDidRender=function(){var c;this.host.querySelectorAll("#social-slot").forEach((function(c){return c.replaceWith(c.firstChild)}));(c=this.host.querySelector('[slot="social"]'))===null||c===void 0?void 0:c.remove()};Object.defineProperty(c.prototype,"host",{get:function(){return getElement(this)},enumerable:false,configurable:true});return c}();SallaSocial.style=sallaSocialCss;export{SallaSocial as salla_social};
5
5
  //# sourceMappingURL=salla-social.entry.js.map