@pradip1995/create-storefront 1.0.1

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 (338) hide show
  1. package/bin/create-storefront.js +239 -0
  2. package/lib/kit-next-config.js +84 -0
  3. package/package.json +32 -0
  4. package/templates/storefront/.eslintrc.json +3 -0
  5. package/templates/storefront/README.md +35 -0
  6. package/templates/storefront/check-env-variables.js +51 -0
  7. package/templates/storefront/kit-next-config.js +71 -0
  8. package/templates/storefront/next-env.d.ts +5 -0
  9. package/templates/storefront/next.config.js +25 -0
  10. package/templates/storefront/package.json +56 -0
  11. package/templates/storefront/postcss.config.js +6 -0
  12. package/templates/storefront/public/favicon.png +0 -0
  13. package/templates/storefront/src/app/[countryCode]/(checkout)/checkout/page.tsx +23 -0
  14. package/templates/storefront/src/app/[countryCode]/(checkout)/checkout/payment/page.tsx +47 -0
  15. package/templates/storefront/src/app/[countryCode]/(checkout)/layout.tsx +31 -0
  16. package/templates/storefront/src/app/[countryCode]/(checkout)/not-found.tsx +19 -0
  17. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/addresses/page.tsx +31 -0
  18. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/loading.tsx +9 -0
  19. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/orders/details/[id]/page.tsx +35 -0
  20. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/orders/exchange/[id]/page.tsx +47 -0
  21. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/orders/page.tsx +28 -0
  22. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/orders/return/[id]/page.tsx +66 -0
  23. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/page.tsx +22 -0
  24. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/payment-methods/page.tsx +23 -0
  25. package/templates/storefront/src/app/[countryCode]/(main)/account/@dashboard/profile/page.tsx +43 -0
  26. package/templates/storefront/src/app/[countryCode]/(main)/account/@login/default.tsx +11 -0
  27. package/templates/storefront/src/app/[countryCode]/(main)/account/@login/page.tsx +18 -0
  28. package/templates/storefront/src/app/[countryCode]/(main)/account/guest-orders/page.tsx +13 -0
  29. package/templates/storefront/src/app/[countryCode]/(main)/account/layout.tsx +22 -0
  30. package/templates/storefront/src/app/[countryCode]/(main)/account/loading.tsx +9 -0
  31. package/templates/storefront/src/app/[countryCode]/(main)/cart/loading.tsx +5 -0
  32. package/templates/storefront/src/app/[countryCode]/(main)/cart/not-found.tsx +21 -0
  33. package/templates/storefront/src/app/[countryCode]/(main)/cart/page.tsx +23 -0
  34. package/templates/storefront/src/app/[countryCode]/(main)/categories/[...category]/page.tsx +11 -0
  35. package/templates/storefront/src/app/[countryCode]/(main)/collections/[handle]/page.tsx +11 -0
  36. package/templates/storefront/src/app/[countryCode]/(main)/contact/page.tsx +21 -0
  37. package/templates/storefront/src/app/[countryCode]/(main)/guest-orders/page.tsx +12 -0
  38. package/templates/storefront/src/app/[countryCode]/(main)/help/page.tsx +28 -0
  39. package/templates/storefront/src/app/[countryCode]/(main)/layout.tsx +21 -0
  40. package/templates/storefront/src/app/[countryCode]/(main)/not-found.tsx +20 -0
  41. package/templates/storefront/src/app/[countryCode]/(main)/order/[id]/confirmed/loading.tsx +5 -0
  42. package/templates/storefront/src/app/[countryCode]/(main)/order/[id]/confirmed/page.tsx +23 -0
  43. package/templates/storefront/src/app/[countryCode]/(main)/order/[id]/transfer/[token]/accept/page.tsx +41 -0
  44. package/templates/storefront/src/app/[countryCode]/(main)/order/[id]/transfer/[token]/decline/page.tsx +41 -0
  45. package/templates/storefront/src/app/[countryCode]/(main)/order/[id]/transfer/[token]/page.tsx +38 -0
  46. package/templates/storefront/src/app/[countryCode]/(main)/order/exchange/[id]/page.tsx +47 -0
  47. package/templates/storefront/src/app/[countryCode]/(main)/order/return/[id]/page.tsx +61 -0
  48. package/templates/storefront/src/app/[countryCode]/(main)/orders/[id]/page.tsx +33 -0
  49. package/templates/storefront/src/app/[countryCode]/(main)/page.tsx +24 -0
  50. package/templates/storefront/src/app/[countryCode]/(main)/privacy-policy/page.tsx +173 -0
  51. package/templates/storefront/src/app/[countryCode]/(main)/products/[handle]/page.tsx +193 -0
  52. package/templates/storefront/src/app/[countryCode]/(main)/reset-password/page.tsx +192 -0
  53. package/templates/storefront/src/app/[countryCode]/(main)/store/page.tsx +72 -0
  54. package/templates/storefront/src/app/[countryCode]/(main)/terms-of-use/page.tsx +179 -0
  55. package/templates/storefront/src/app/[countryCode]/(main)/wishlist/page.tsx +19 -0
  56. package/templates/storefront/src/app/api/meta/event/route.ts +63 -0
  57. package/templates/storefront/src/app/auth/customer/google/callback/page.tsx +126 -0
  58. package/templates/storefront/src/app/layout.tsx +104 -0
  59. package/templates/storefront/src/app/not-found.tsx +30 -0
  60. package/templates/storefront/src/app/opengraph-image.jpg +0 -0
  61. package/templates/storefront/src/app/robots.ts +15 -0
  62. package/templates/storefront/src/app/sitemap.ts +65 -0
  63. package/templates/storefront/src/app/twitter-image.jpg +0 -0
  64. package/templates/storefront/src/modules/account/components/account-deletion/index.tsx +160 -0
  65. package/templates/storefront/src/modules/account/components/account-info/index.tsx +145 -0
  66. package/templates/storefront/src/modules/account/components/account-nav/icons.tsx +43 -0
  67. package/templates/storefront/src/modules/account/components/account-nav/index.tsx +318 -0
  68. package/templates/storefront/src/modules/account/components/account-nav/logout-modal.tsx +92 -0
  69. package/templates/storefront/src/modules/account/components/account-nav/payment-methods-icon.tsx +9 -0
  70. package/templates/storefront/src/modules/account/components/address-book/index.tsx +47 -0
  71. package/templates/storefront/src/modules/account/components/address-card/add-address.tsx +377 -0
  72. package/templates/storefront/src/modules/account/components/address-card/edit-address-modal.tsx +468 -0
  73. package/templates/storefront/src/modules/account/components/deletion-pending-modal/index.tsx +213 -0
  74. package/templates/storefront/src/modules/account/components/forgot-password/index.tsx +1 -0
  75. package/templates/storefront/src/modules/account/components/login/index.tsx +1 -0
  76. package/templates/storefront/src/modules/account/components/order-card/index.tsx +221 -0
  77. package/templates/storefront/src/modules/account/components/order-overview/index.tsx +159 -0
  78. package/templates/storefront/src/modules/account/components/overview/index.tsx +189 -0
  79. package/templates/storefront/src/modules/account/components/profile-billing-address/index.tsx +447 -0
  80. package/templates/storefront/src/modules/account/components/profile-email/index.tsx +75 -0
  81. package/templates/storefront/src/modules/account/components/profile-form/index.tsx +416 -0
  82. package/templates/storefront/src/modules/account/components/profile-name/index.tsx +76 -0
  83. package/templates/storefront/src/modules/account/components/profile-password/index.tsx +70 -0
  84. package/templates/storefront/src/modules/account/components/profile-phone/index.tsx +185 -0
  85. package/templates/storefront/src/modules/account/components/register/index.tsx +1 -0
  86. package/templates/storefront/src/modules/account/components/return-item-selector/index.tsx +187 -0
  87. package/templates/storefront/src/modules/account/components/return-shipping-selector/index.tsx +118 -0
  88. package/templates/storefront/src/modules/account/components/transfer-request-form/index.tsx +81 -0
  89. package/templates/storefront/src/modules/account/templates/account-layout.tsx +38 -0
  90. package/templates/storefront/src/modules/account/templates/exchange-request-template.tsx +389 -0
  91. package/templates/storefront/src/modules/account/templates/guest-orders-template.tsx +123 -0
  92. package/templates/storefront/src/modules/account/templates/login-template.tsx +44 -0
  93. package/templates/storefront/src/modules/account/templates/payment-methods-template.tsx +478 -0
  94. package/templates/storefront/src/modules/account/templates/return-request-template.tsx +300 -0
  95. package/templates/storefront/src/modules/cart/components/abandoned-carts/ScrollToPendingOrdersButton.tsx +21 -0
  96. package/templates/storefront/src/modules/cart/components/abandoned-carts/index.tsx +335 -0
  97. package/templates/storefront/src/modules/cart/components/applied-promotions/index.tsx +121 -0
  98. package/templates/storefront/src/modules/cart/components/cart-delivery-selection/index.tsx +203 -0
  99. package/templates/storefront/src/modules/cart/components/cart-item-card/index.tsx +476 -0
  100. package/templates/storefront/src/modules/cart/components/cart-item-select/index.tsx +73 -0
  101. package/templates/storefront/src/modules/cart/components/cart-view-tracker/index.tsx +44 -0
  102. package/templates/storefront/src/modules/cart/components/delivery-information/index.tsx +89 -0
  103. package/templates/storefront/src/modules/cart/components/empty-cart-message/index.tsx +38 -0
  104. package/templates/storefront/src/modules/cart/components/item/index.tsx +150 -0
  105. package/templates/storefront/src/modules/cart/components/pincode-checker/index.tsx +174 -0
  106. package/templates/storefront/src/modules/cart/components/sign-in-prompt/index.tsx +26 -0
  107. package/templates/storefront/src/modules/cart/components/you-may-also-like/index.tsx +137 -0
  108. package/templates/storefront/src/modules/cart/templates/index.tsx +88 -0
  109. package/templates/storefront/src/modules/cart/templates/items.tsx +49 -0
  110. package/templates/storefront/src/modules/cart/templates/preview.tsx +51 -0
  111. package/templates/storefront/src/modules/cart/templates/summary.tsx +29 -0
  112. package/templates/storefront/src/modules/checkout/components/add-address-modal/index.tsx +390 -0
  113. package/templates/storefront/src/modules/checkout/components/address-card/index.tsx +135 -0
  114. package/templates/storefront/src/modules/checkout/components/address-select/index.tsx +116 -0
  115. package/templates/storefront/src/modules/checkout/components/addresses/index.tsx +605 -0
  116. package/templates/storefront/src/modules/checkout/components/back-link/index.tsx +32 -0
  117. package/templates/storefront/src/modules/checkout/components/billing_address/index.tsx +301 -0
  118. package/templates/storefront/src/modules/checkout/components/checkout-begin-tracker/index.tsx +45 -0
  119. package/templates/storefront/src/modules/checkout/components/checkout-leave-guard/index.tsx +109 -0
  120. package/templates/storefront/src/modules/checkout/components/checkout-shipping-tracker/index.tsx +45 -0
  121. package/templates/storefront/src/modules/checkout/components/country-select/index.tsx +50 -0
  122. package/templates/storefront/src/modules/checkout/components/discount-code/index.tsx +220 -0
  123. package/templates/storefront/src/modules/checkout/components/error-message/index.tsx +13 -0
  124. package/templates/storefront/src/modules/checkout/components/payment/index.tsx +572 -0
  125. package/templates/storefront/src/modules/checkout/components/payment-button/index.tsx +257 -0
  126. package/templates/storefront/src/modules/checkout/components/payment-button/razorpay-payment-button.tsx +136 -0
  127. package/templates/storefront/src/modules/checkout/components/payment-container/index.tsx +129 -0
  128. package/templates/storefront/src/modules/checkout/components/payment-test/index.tsx +12 -0
  129. package/templates/storefront/src/modules/checkout/components/payment-wrapper/index.tsx +50 -0
  130. package/templates/storefront/src/modules/checkout/components/payment-wrapper/stripe-wrapper.tsx +54 -0
  131. package/templates/storefront/src/modules/checkout/components/processing-overlay/index.tsx +83 -0
  132. package/templates/storefront/src/modules/checkout/components/review/index.tsx +60 -0
  133. package/templates/storefront/src/modules/checkout/components/select-address-modal/index.tsx +103 -0
  134. package/templates/storefront/src/modules/checkout/components/shipping/index.tsx +533 -0
  135. package/templates/storefront/src/modules/checkout/components/shipping-address/index.tsx +521 -0
  136. package/templates/storefront/src/modules/checkout/components/submit-button/index.tsx +32 -0
  137. package/templates/storefront/src/modules/checkout/templates/checkout-form/index.tsx +38 -0
  138. package/templates/storefront/src/modules/checkout/templates/checkout-summary/index.tsx +274 -0
  139. package/templates/storefront/src/modules/common/components/breadcrumb/index.tsx +43 -0
  140. package/templates/storefront/src/modules/common/components/cart-totals/index.tsx +473 -0
  141. package/templates/storefront/src/modules/common/components/checkbox/index.tsx +98 -0
  142. package/templates/storefront/src/modules/common/components/delete-button/index.tsx +156 -0
  143. package/templates/storefront/src/modules/common/components/divider/index.tsx +9 -0
  144. package/templates/storefront/src/modules/common/components/filter-checkbox-group/index.tsx +134 -0
  145. package/templates/storefront/src/modules/common/components/filter-radio-group/index.tsx +62 -0
  146. package/templates/storefront/src/modules/common/components/input/index.tsx +79 -0
  147. package/templates/storefront/src/modules/common/components/interactive-link/index.tsx +33 -0
  148. package/templates/storefront/src/modules/common/components/line-item-options/index.tsx +26 -0
  149. package/templates/storefront/src/modules/common/components/line-item-price/index.tsx +64 -0
  150. package/templates/storefront/src/modules/common/components/line-item-unit-price/index.tsx +61 -0
  151. package/templates/storefront/src/modules/common/components/localized-client-link/index.tsx +32 -0
  152. package/templates/storefront/src/modules/common/components/login-popup/index.tsx +78 -0
  153. package/templates/storefront/src/modules/common/components/modal/index.tsx +123 -0
  154. package/templates/storefront/src/modules/common/components/native-select/index.tsx +75 -0
  155. package/templates/storefront/src/modules/common/components/obfuscated-email/index.tsx +30 -0
  156. package/templates/storefront/src/modules/common/components/product/product-rating/index.tsx +172 -0
  157. package/templates/storefront/src/modules/common/components/product/review-modal/index.tsx +333 -0
  158. package/templates/storefront/src/modules/common/components/product/share-button/index.tsx +227 -0
  159. package/templates/storefront/src/modules/common/components/product/wishlist-icon/index.tsx +46 -0
  160. package/templates/storefront/src/modules/common/components/radio/index.tsx +27 -0
  161. package/templates/storefront/src/modules/common/components/select/index.tsx +164 -0
  162. package/templates/storefront/src/modules/common/components/side-panel/index.tsx +65 -0
  163. package/templates/storefront/src/modules/common/icons/arrow-left.tsx +36 -0
  164. package/templates/storefront/src/modules/common/icons/back.tsx +37 -0
  165. package/templates/storefront/src/modules/common/icons/bancontact.tsx +26 -0
  166. package/templates/storefront/src/modules/common/icons/chevron-down.tsx +30 -0
  167. package/templates/storefront/src/modules/common/icons/delivered.tsx +29 -0
  168. package/templates/storefront/src/modules/common/icons/envelope.tsx +27 -0
  169. package/templates/storefront/src/modules/common/icons/eye-off.tsx +37 -0
  170. package/templates/storefront/src/modules/common/icons/eye.tsx +37 -0
  171. package/templates/storefront/src/modules/common/icons/fast-delivery.tsx +65 -0
  172. package/templates/storefront/src/modules/common/icons/ideal.tsx +26 -0
  173. package/templates/storefront/src/modules/common/icons/lock.tsx +31 -0
  174. package/templates/storefront/src/modules/common/icons/map-pin.tsx +37 -0
  175. package/templates/storefront/src/modules/common/icons/medusa.tsx +27 -0
  176. package/templates/storefront/src/modules/common/icons/menu.tsx +45 -0
  177. package/templates/storefront/src/modules/common/icons/nextjs.tsx +27 -0
  178. package/templates/storefront/src/modules/common/icons/package.tsx +44 -0
  179. package/templates/storefront/src/modules/common/icons/paypal.tsx +30 -0
  180. package/templates/storefront/src/modules/common/icons/phone.tsx +30 -0
  181. package/templates/storefront/src/modules/common/icons/placeholder-image.tsx +44 -0
  182. package/templates/storefront/src/modules/common/icons/refresh.tsx +51 -0
  183. package/templates/storefront/src/modules/common/icons/spinner.tsx +37 -0
  184. package/templates/storefront/src/modules/common/icons/trash.tsx +51 -0
  185. package/templates/storefront/src/modules/common/icons/user.tsx +37 -0
  186. package/templates/storefront/src/modules/common/icons/x.tsx +37 -0
  187. package/templates/storefront/src/modules/contact/templates/index.tsx +272 -0
  188. package/templates/storefront/src/modules/help/templates/index.tsx +629 -0
  189. package/templates/storefront/src/modules/home/components/dynamic-banner/index.tsx +190 -0
  190. package/templates/storefront/src/modules/home/components/featured-products/index.tsx +16 -0
  191. package/templates/storefront/src/modules/home/components/featured-products/product-rail/index.tsx +51 -0
  192. package/templates/storefront/src/modules/home/components/features/index.tsx +1 -0
  193. package/templates/storefront/src/modules/home/components/hero/index.tsx +1 -0
  194. package/templates/storefront/src/modules/home/components/loved-by-moms/index.tsx +1 -0
  195. package/templates/storefront/src/modules/home/components/new-arrivals/index.tsx +1 -0
  196. package/templates/storefront/src/modules/home/components/shop-by-age/index.tsx +1 -0
  197. package/templates/storefront/src/modules/home/components/shop-by-category/index.tsx +1 -0
  198. package/templates/storefront/src/modules/home/components/testimonials/index.tsx +1 -0
  199. package/templates/storefront/src/modules/home/components/why-choose-us/dynamic-features.tsx +93 -0
  200. package/templates/storefront/src/modules/home/components/why-choose-us/index.tsx +1 -0
  201. package/templates/storefront/src/modules/layout/components/account-dropdown/index.tsx +56 -0
  202. package/templates/storefront/src/modules/layout/components/cart-button/index.tsx +8 -0
  203. package/templates/storefront/src/modules/layout/components/cart-dropdown/index.tsx +424 -0
  204. package/templates/storefront/src/modules/layout/components/cart-mismatch-banner/index.tsx +57 -0
  205. package/templates/storefront/src/modules/layout/components/cookie-consent/index.tsx +116 -0
  206. package/templates/storefront/src/modules/layout/components/country-select/index.tsx +135 -0
  207. package/templates/storefront/src/modules/layout/components/desktop-search/index.tsx +148 -0
  208. package/templates/storefront/src/modules/layout/components/dynamic-logo/index.tsx +27 -0
  209. package/templates/storefront/src/modules/layout/components/footer-categories/index.tsx +34 -0
  210. package/templates/storefront/src/modules/layout/components/footer-contact/index.tsx +87 -0
  211. package/templates/storefront/src/modules/layout/components/footer-description/index.tsx +12 -0
  212. package/templates/storefront/src/modules/layout/components/footer-logo/index.tsx +22 -0
  213. package/templates/storefront/src/modules/layout/components/footer-newsletter/index.tsx +100 -0
  214. package/templates/storefront/src/modules/layout/components/language-select/index.tsx +192 -0
  215. package/templates/storefront/src/modules/layout/components/medusa-cta/index.tsx +21 -0
  216. package/templates/storefront/src/modules/layout/components/mobile-menu/index.tsx +296 -0
  217. package/templates/storefront/src/modules/layout/components/nav-links/index.tsx +66 -0
  218. package/templates/storefront/src/modules/layout/components/nav-wrapper/index.tsx +14 -0
  219. package/templates/storefront/src/modules/layout/components/promo-bar/index.tsx +7 -0
  220. package/templates/storefront/src/modules/layout/components/promo-bar/promo-bar-content.tsx +174 -0
  221. package/templates/storefront/src/modules/layout/components/push-notification-manager/index.tsx +191 -0
  222. package/templates/storefront/src/modules/layout/components/search-panel/index.tsx +136 -0
  223. package/templates/storefront/src/modules/layout/components/side-menu/index.tsx +144 -0
  224. package/templates/storefront/src/modules/layout/components/verification-banner/index.tsx +217 -0
  225. package/templates/storefront/src/modules/layout/components/wishlist-counter/index.tsx +17 -0
  226. package/templates/storefront/src/modules/layout/templates/footer/index.tsx +7 -0
  227. package/templates/storefront/src/modules/layout/templates/nav/index.tsx +14 -0
  228. package/templates/storefront/src/modules/order/components/cancel-order-modal/index.tsx +168 -0
  229. package/templates/storefront/src/modules/order/components/help/index.tsx +25 -0
  230. package/templates/storefront/src/modules/order/components/item/index.tsx +62 -0
  231. package/templates/storefront/src/modules/order/components/items/index.tsx +44 -0
  232. package/templates/storefront/src/modules/order/components/onboarding-cta/index.tsx +28 -0
  233. package/templates/storefront/src/modules/order/components/order-confirmation-back-handler/index.tsx +28 -0
  234. package/templates/storefront/src/modules/order/components/order-details/index.tsx +63 -0
  235. package/templates/storefront/src/modules/order/components/order-purchase-tracker/index.tsx +48 -0
  236. package/templates/storefront/src/modules/order/components/order-redesign/index.tsx +887 -0
  237. package/templates/storefront/src/modules/order/components/order-summary/index.tsx +60 -0
  238. package/templates/storefront/src/modules/order/components/payment-details/index.tsx +63 -0
  239. package/templates/storefront/src/modules/order/components/shipping-details/index.tsx +73 -0
  240. package/templates/storefront/src/modules/order/components/transfer-actions/index.tsx +81 -0
  241. package/templates/storefront/src/modules/order/components/transfer-image/index.tsx +275 -0
  242. package/templates/storefront/src/modules/order/templates/order-completed-template.tsx +233 -0
  243. package/templates/storefront/src/modules/order/templates/order-details-template.tsx +128 -0
  244. package/templates/storefront/src/modules/products/components/image-gallery/index.tsx +297 -0
  245. package/templates/storefront/src/modules/products/components/product-actions/index.tsx +1400 -0
  246. package/templates/storefront/src/modules/products/components/product-actions/mobile-actions.tsx +217 -0
  247. package/templates/storefront/src/modules/products/components/product-actions/option-select.tsx +62 -0
  248. package/templates/storefront/src/modules/products/components/product-onboarding-cta/index.tsx +30 -0
  249. package/templates/storefront/src/modules/products/components/product-preview/index.tsx +5 -0
  250. package/templates/storefront/src/modules/products/components/product-preview/price.tsx +29 -0
  251. package/templates/storefront/src/modules/products/components/product-price/index.tsx +58 -0
  252. package/templates/storefront/src/modules/products/components/product-rating/index.tsx +1 -0
  253. package/templates/storefront/src/modules/products/components/product-tabs/accordion.tsx +100 -0
  254. package/templates/storefront/src/modules/products/components/product-tabs/index.tsx +127 -0
  255. package/templates/storefront/src/modules/products/components/product-tabs/ratings-tab.tsx +598 -0
  256. package/templates/storefront/src/modules/products/components/product-view-tracker/index.tsx +53 -0
  257. package/templates/storefront/src/modules/products/components/related-products/index.tsx +152 -0
  258. package/templates/storefront/src/modules/products/components/review-modal/index.tsx +1 -0
  259. package/templates/storefront/src/modules/products/components/share-button/index.tsx +1 -0
  260. package/templates/storefront/src/modules/products/components/thumbnail/index.tsx +91 -0
  261. package/templates/storefront/src/modules/products/components/wishlist-icon/index.tsx +1 -0
  262. package/templates/storefront/src/modules/products/context/product-context.tsx +52 -0
  263. package/templates/storefront/src/modules/products/templates/index.tsx +26 -0
  264. package/templates/storefront/src/modules/products/templates/product-actions-wrapper/index.tsx +1 -0
  265. package/templates/storefront/src/modules/products/templates/product-info/index.tsx +2 -0
  266. package/templates/storefront/src/modules/shipping/components/free-shipping-price-nudge/index.tsx +283 -0
  267. package/templates/storefront/src/modules/skeletons/components/skeleton-button/index.tsx +5 -0
  268. package/templates/storefront/src/modules/skeletons/components/skeleton-card-details/index.tsx +10 -0
  269. package/templates/storefront/src/modules/skeletons/components/skeleton-cart-item/index.tsx +35 -0
  270. package/templates/storefront/src/modules/skeletons/components/skeleton-cart-totals/index.tsx +30 -0
  271. package/templates/storefront/src/modules/skeletons/components/skeleton-code-form/index.tsx +13 -0
  272. package/templates/storefront/src/modules/skeletons/components/skeleton-line-item/index.tsx +35 -0
  273. package/templates/storefront/src/modules/skeletons/components/skeleton-order-confirmed-header/index.tsx +14 -0
  274. package/templates/storefront/src/modules/skeletons/components/skeleton-order-information/index.tsx +36 -0
  275. package/templates/storefront/src/modules/skeletons/components/skeleton-order-items/index.tsx +43 -0
  276. package/templates/storefront/src/modules/skeletons/components/skeleton-order-summary/index.tsx +15 -0
  277. package/templates/storefront/src/modules/skeletons/components/skeleton-product-preview/index.tsx +15 -0
  278. package/templates/storefront/src/modules/skeletons/templates/skeleton-cart-page/index.tsx +65 -0
  279. package/templates/storefront/src/modules/skeletons/templates/skeleton-order-confirmed/index.tsx +21 -0
  280. package/templates/storefront/src/modules/skeletons/templates/skeleton-product-grid/index.tsx +23 -0
  281. package/templates/storefront/src/modules/skeletons/templates/skeleton-related-products/index.tsx +25 -0
  282. package/templates/storefront/src/modules/store/components/client-paginated-products.tsx +108 -0
  283. package/templates/storefront/src/modules/store/components/mobile-filters/index.tsx +135 -0
  284. package/templates/storefront/src/modules/store/components/pagination/index.tsx +118 -0
  285. package/templates/storefront/src/modules/store/components/product-list-view-tracker/index.tsx +43 -0
  286. package/templates/storefront/src/modules/store/components/refinement-list/index.tsx +299 -0
  287. package/templates/storefront/src/modules/store/components/refinement-list/sort-products/index.tsx +120 -0
  288. package/templates/storefront/src/modules/store/components/store-header/index.tsx +67 -0
  289. package/templates/storefront/src/modules/store/templates/index.tsx +1 -0
  290. package/templates/storefront/src/modules/store/templates/paginated-products.tsx +175 -0
  291. package/templates/storefront/src/modules/wishlist/components/wishlist-item/index.tsx +797 -0
  292. package/templates/storefront/src/modules/wishlist/templates/index.tsx +176 -0
  293. package/templates/storefront/src/storefront.config.ts +12 -0
  294. package/templates/storefront/src/styles/globals.css +326 -0
  295. package/templates/storefront/src/theme/valero/blocks/home/Features/index.tsx +61 -0
  296. package/templates/storefront/src/theme/valero/blocks/home/Hero/index.tsx +102 -0
  297. package/templates/storefront/src/theme/valero/blocks/home/LovedByMoms/index.tsx +407 -0
  298. package/templates/storefront/src/theme/valero/blocks/home/NewArrivals/index.tsx +48 -0
  299. package/templates/storefront/src/theme/valero/blocks/home/ShopByAge/index.tsx +128 -0
  300. package/templates/storefront/src/theme/valero/blocks/home/ShopByCategory/index.tsx +409 -0
  301. package/templates/storefront/src/theme/valero/blocks/home/Testimonials/index.tsx +697 -0
  302. package/templates/storefront/src/theme/valero/blocks/home/WhyChooseUs/index.tsx +62 -0
  303. package/templates/storefront/src/theme/valero/layouts/MainLayoutShell.tsx +14 -0
  304. package/templates/storefront/src/theme/valero/primitives/Button.tsx +28 -0
  305. package/templates/storefront/src/theme/valero/primitives/Card.tsx +32 -0
  306. package/templates/storefront/src/theme/valero/primitives/index.ts +2 -0
  307. package/templates/storefront/src/theme/valero/slots/account/ForgotPassword/index.tsx +1 -0
  308. package/templates/storefront/src/theme/valero/slots/account/Login/index.tsx +1 -0
  309. package/templates/storefront/src/theme/valero/slots/account/LoginTemplate/index.tsx +44 -0
  310. package/templates/storefront/src/theme/valero/slots/account/Register/index.tsx +1 -0
  311. package/templates/storefront/src/theme/valero/slots/cart/CartItem/index.tsx +11 -0
  312. package/templates/storefront/src/theme/valero/slots/cart/CartSummary/index.tsx +13 -0
  313. package/templates/storefront/src/theme/valero/slots/checkout/CheckoutForm/index.tsx +1 -0
  314. package/templates/storefront/src/theme/valero/slots/checkout/CheckoutSummary/index.tsx +1 -0
  315. package/templates/storefront/src/theme/valero/slots/layout/Footer/index.tsx +104 -0
  316. package/templates/storefront/src/theme/valero/slots/layout/Nav/index.tsx +97 -0
  317. package/templates/storefront/src/theme/valero/slots/layout/PromoBar/index.tsx +19 -0
  318. package/templates/storefront/src/theme/valero/slots/layout/PromoBar/promo-bar-content.tsx +174 -0
  319. package/templates/storefront/src/theme/valero/slots/order/OrderDetails/index.tsx +12 -0
  320. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductCTASection.tsx +191 -0
  321. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductDetailsSection.tsx +137 -0
  322. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductFeaturePanel.tsx +245 -0
  323. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductHighlightsSection.tsx +98 -0
  324. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductOptionsSection.tsx +233 -0
  325. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductPriceSection.tsx +53 -0
  326. package/templates/storefront/src/theme/valero/slots/product/ProductActions/ProductTrustSection.tsx +84 -0
  327. package/templates/storefront/src/theme/valero/slots/product/ProductActions/index.tsx +161 -0
  328. package/templates/storefront/src/theme/valero/slots/product/ProductCard/index.tsx +132 -0
  329. package/templates/storefront/src/theme/valero/slots/product/ProductInfo/index.tsx +40 -0
  330. package/templates/storefront/src/theme/valero/templates/StorePage/index.tsx +154 -0
  331. package/templates/storefront/src/theme/valero/tokens/colors.js +16 -0
  332. package/templates/storefront/src/theme/valero/tokens/colors.ts +21 -0
  333. package/templates/storefront/src/theme/valero/tokens/fonts.ts +13 -0
  334. package/templates/storefront/src/theme/valero/tokens/index.ts +3 -0
  335. package/templates/storefront/src/theme/valero/tokens/spacing.ts +9 -0
  336. package/templates/storefront/src/theme/valero/tokens/theme.css +91 -0
  337. package/templates/storefront/tailwind.config.js +221 -0
  338. package/templates/storefront/tsconfig.json +30 -0
@@ -0,0 +1,78 @@
1
+ "use client"
2
+
3
+ import { useRouter, usePathname } from "next/navigation"
4
+
5
+ interface LoginPopupProps {
6
+ isOpen: boolean
7
+ onClose: () => void
8
+ countryCode?: string
9
+ message?: string
10
+ }
11
+
12
+ export default function LoginPopup({ isOpen, onClose, countryCode = "us", message = "Please login to add products to your wishlist." }: LoginPopupProps) {
13
+ const router = useRouter()
14
+ const pathname = usePathname()
15
+
16
+ const handleLoginClick = () => {
17
+ // Store current URL in localStorage for redirect after login
18
+ if (typeof window !== "undefined") {
19
+ const currentPath = pathname || window.location.pathname
20
+ // Add a special marker so the login component knows to keep the user on this page
21
+ const redirectWithContext = currentPath.includes('?')
22
+ ? `${currentPath}&login_context=keep`
23
+ : `${currentPath}?login_context=keep`
24
+
25
+ localStorage.setItem("loginRedirectUrl", redirectWithContext)
26
+ }
27
+ router.push(`/${countryCode}/account`)
28
+ }
29
+
30
+ if (!isOpen) {
31
+ return null
32
+ }
33
+
34
+ return (
35
+ <div className="fixed inset-0 z-[9999] flex items-center justify-center bg-white/10 backdrop-blur-md p-4 animate-in fade-in duration-200">
36
+ <div
37
+ className="bg-[#FFFAFE] rounded-2xl shadow-2xl p-8 max-w-sm w-full mx-auto border border-gray-100 transform transition-all scale-100 animate-in zoom-in-95 duration-200"
38
+ onClick={(e) => e.stopPropagation()}
39
+ >
40
+ <div className="text-center">
41
+ <div className="mx-auto flex items-center justify-center h-12 w-12 rounded-full bg-purple-100 mb-4">
42
+ <svg className="h-6 w-6 text-[#8B5AB1]" fill="none" viewBox="0 0 24 24" stroke="currentColor">
43
+ <path strokeLinecap="round" strokeLinejoin="round" strokeWidth="2" d="M12 15v2m-6 4h12a2 2 0 002-2v-6a2 2 0 00-2-2H6a2 2 0 00-2 2v6a2 2 0 002 2zm10-10V7a4 4 0 00-8 0v4h8z" />
44
+ </svg>
45
+ </div>
46
+ <h2 className="text-xl font-bold text-gray-900 mb-2">
47
+ Login Required
48
+ </h2>
49
+ <p className="text-gray-500 mb-8 text-sm leading-relaxed">
50
+ {message}
51
+ </p>
52
+
53
+ <div className="grid grid-cols-2 gap-3">
54
+ <button
55
+ onClick={onClose}
56
+ className="px-4 py-2.5 border border-gray-200 rounded-xl font-semibold text-gray-600 hover:bg-gray-50 hover:border-gray-300 active:scale-95 transition-all duration-200"
57
+ >
58
+ Cancel
59
+ </button>
60
+ <button
61
+ onClick={handleLoginClick}
62
+ className="px-4 py-2.5 rounded-xl font-semibold text-white transition-all duration-200 hover:shadow-lg hover:shadow-purple-100 active:scale-95"
63
+ style={{ backgroundColor: '#8B5AB1' }}
64
+ onMouseEnter={(e) => {
65
+ e.currentTarget.style.backgroundColor = '#7a4a9a'
66
+ }}
67
+ onMouseLeave={(e) => {
68
+ e.currentTarget.style.backgroundColor = '#8B5AB1'
69
+ }}
70
+ >
71
+ Login
72
+ </button>
73
+ </div>
74
+ </div>
75
+ </div>
76
+ </div>
77
+ )
78
+ }
@@ -0,0 +1,123 @@
1
+ import { Dialog, Transition } from "@headlessui/react"
2
+ import { clx } from "@medusajs/ui"
3
+ import React, { Fragment } from "react"
4
+
5
+ import { ModalProvider, useModal } from "@core/context/modal-context"
6
+ import X from "@modules/common/icons/x"
7
+
8
+ type ModalProps = {
9
+ isOpen: boolean
10
+ close: () => void
11
+ size?: "tiny" | "xsmall" | "small" | "medium" | "large"
12
+ search?: boolean
13
+ children: React.ReactNode
14
+ 'data-testid'?: string
15
+ }
16
+
17
+ const Modal = ({
18
+ isOpen,
19
+ close,
20
+ size = "medium",
21
+ search = false,
22
+ children,
23
+ 'data-testid': dataTestId
24
+ }: ModalProps) => {
25
+ return (
26
+ <Transition appear show={isOpen} as={Fragment}>
27
+ <Dialog as="div" className="relative z-[75]" onClose={close}>
28
+ <Transition.Child
29
+ as={Fragment}
30
+ enter="ease-out duration-300"
31
+ enterFrom="opacity-0"
32
+ enterTo="opacity-100"
33
+ leave="ease-in duration-200"
34
+ leaveFrom="opacity-100"
35
+ leaveTo="opacity-0"
36
+ >
37
+ <div className="fixed inset-0 bg-opacity-75 backdrop-blur-md h-screen" />
38
+ </Transition.Child>
39
+
40
+ <div className="fixed inset-0 overflow-y-hidden">
41
+ <div
42
+ className={clx(
43
+ "flex min-h-full h-full justify-center p-4 text-center",
44
+ {
45
+ "items-center": !search,
46
+ "items-start": search,
47
+ }
48
+ )}
49
+ >
50
+ <Transition.Child
51
+ as={Fragment}
52
+ enter="ease-out duration-300"
53
+ enterFrom="opacity-0 scale-95"
54
+ enterTo="opacity-100 scale-100"
55
+ leave="ease-in duration-200"
56
+ leaveFrom="opacity-100 scale-100"
57
+ leaveTo="opacity-0 scale-95"
58
+ >
59
+ <Dialog.Panel
60
+ data-testid={dataTestId}
61
+ className={clx(
62
+ "flex flex-col justify-start w-full transform p-0 text-left align-middle transition-all max-h-[90vh] overflow-hidden bg-white shadow-xl border rounded-[32px]",
63
+ {
64
+ "max-w-[320px] mx-auto": size === "tiny",
65
+ "max-w-[320px] min-[400px]:max-w-[400px] min-[640px]:max-w-[450px] mx-auto": size === "xsmall",
66
+ "max-w-md": size === "small",
67
+ "max-w-xl": size === "medium",
68
+ "max-w-3xl": size === "large",
69
+ "bg-transparent shadow-none": search,
70
+ }
71
+ )}
72
+ >
73
+ <ModalProvider close={close}>
74
+ <div className="flex flex-col flex-1 h-full overflow-hidden">
75
+ {children}
76
+ </div>
77
+ </ModalProvider>
78
+ </Dialog.Panel>
79
+ </Transition.Child>
80
+ </div>
81
+ </div>
82
+ </Dialog>
83
+ </Transition>
84
+ )
85
+ }
86
+
87
+ const Title: React.FC<{ children: React.ReactNode }> = ({ children }) => {
88
+ const { close } = useModal()
89
+
90
+ return (
91
+ <Dialog.Title className="flex items-center justify-between px-6 small:px-8 py-5 border-b border-gray-100 flex-shrink-0">
92
+ <div className="text-xl small:text-2xl font-bold text-gray-900">{children}</div>
93
+ <div>
94
+ <button onClick={close} data-testid="close-modal-button" className="p-2 hover:bg-gray-100 rounded-full transition-colors text-gray-500">
95
+ <X size={24} />
96
+ </button>
97
+ </div>
98
+ </Dialog.Title>
99
+ )
100
+ }
101
+
102
+ const Description: React.FC<{ children: React.ReactNode }> = ({ children }) => {
103
+ return (
104
+ <Dialog.Description className="flex text-small-regular text-ui-fg-base items-center justify-center pt-2 pb-4 h-full">
105
+ {children}
106
+ </Dialog.Description>
107
+ )
108
+ }
109
+
110
+ const Body: React.FC<{ children: React.ReactNode }> = ({ children }) => {
111
+ return <div className="p-6 small:p-8 overflow-y-auto [&::-webkit-scrollbar]:hidden [-ms-overflow-style:none] [scrollbar-width:none] flex-1">{children}</div>
112
+ }
113
+
114
+ const Footer: React.FC<{ children: React.ReactNode }> = ({ children }) => {
115
+ return <div className="flex items-center justify-end gap-x-4 px-6 small:px-8 py-5 border-t border-gray-100 flex-shrink-0">{children}</div>
116
+ }
117
+
118
+ Modal.Title = Title
119
+ Modal.Description = Description
120
+ Modal.Body = Body
121
+ Modal.Footer = Footer
122
+
123
+ export default Modal
@@ -0,0 +1,75 @@
1
+ import { ChevronUpDown } from "@medusajs/icons"
2
+ import { clx } from "@medusajs/ui"
3
+ import {
4
+ SelectHTMLAttributes,
5
+ forwardRef,
6
+ useEffect,
7
+ useImperativeHandle,
8
+ useRef,
9
+ useState,
10
+ } from "react"
11
+
12
+ export type NativeSelectProps = {
13
+ placeholder?: string
14
+ errors?: Record<string, unknown>
15
+ touched?: Record<string, unknown>
16
+ } & SelectHTMLAttributes<HTMLSelectElement>
17
+
18
+ const NativeSelect = forwardRef<HTMLSelectElement, NativeSelectProps>(
19
+ (
20
+ { placeholder = "Select...", defaultValue, className, children, ...props },
21
+ ref
22
+ ) => {
23
+ const innerRef = useRef<HTMLSelectElement>(null)
24
+ const [isPlaceholder, setIsPlaceholder] = useState(false)
25
+
26
+ useImperativeHandle<HTMLSelectElement | null, HTMLSelectElement | null>(
27
+ ref,
28
+ () => innerRef.current
29
+ )
30
+
31
+ useEffect(() => {
32
+ if (innerRef.current && innerRef.current.value === "") {
33
+ setIsPlaceholder(true)
34
+ } else {
35
+ setIsPlaceholder(false)
36
+ }
37
+ }, [innerRef.current?.value])
38
+
39
+ return (
40
+ <div>
41
+ <div
42
+ onFocus={() => innerRef.current?.focus()}
43
+ onBlur={() => innerRef.current?.blur()}
44
+ className={clx(
45
+ "relative flex items-center text-base-regular border bg-white rounded-lg hover:bg-gray-50",
46
+ className,
47
+ {
48
+ "text-ui-fg-muted": isPlaceholder,
49
+ }
50
+ )}
51
+ style={{ borderColor: '#C0C0C0' }}
52
+ >
53
+ <select
54
+ ref={innerRef}
55
+ defaultValue={defaultValue}
56
+ {...props}
57
+ className="appearance-none flex-1 bg-transparent border-none px-4 py-2.5 transition-colors duration-150 outline-none "
58
+ >
59
+ <option disabled value="">
60
+ {placeholder}
61
+ </option>
62
+ {children}
63
+ </select>
64
+ <span className="absolute right-4 inset-y-0 flex items-center pointer-events-none ">
65
+ <ChevronUpDown />
66
+ </span>
67
+ </div>
68
+ </div>
69
+ )
70
+ }
71
+ )
72
+
73
+ NativeSelect.displayName = "NativeSelect"
74
+
75
+ export default NativeSelect
@@ -0,0 +1,30 @@
1
+ "use client"
2
+
3
+ import React, { useEffect, useState } from "react"
4
+
5
+ interface ObfuscatedEmailProps {
6
+ email: string
7
+ className?: string
8
+ }
9
+
10
+ const ObfuscatedEmail: React.FC<ObfuscatedEmailProps> = ({ email, className }) => {
11
+ const [displayEmail, setDisplayEmail] = useState("")
12
+
13
+ useEffect(() => {
14
+ // Reveal the email only on the client side
15
+ setDisplayEmail(email)
16
+ }, [email])
17
+
18
+ if (!displayEmail) {
19
+ // Hide or show placeholder while loading
20
+ return <span className={className}>...</span>
21
+ }
22
+
23
+ return (
24
+ <a href={`mailto:${displayEmail}`} className={className}>
25
+ {displayEmail}
26
+ </a>
27
+ )
28
+ }
29
+
30
+ export default ObfuscatedEmail
@@ -0,0 +1,172 @@
1
+ "use client"
2
+
3
+ import { useState, useEffect, useMemo } from "react"
4
+ import { HttpTypes } from "@medusajs/types"
5
+ import ReviewModal from "@modules/common/components/product/review-modal"
6
+ import { fetchReviewsForProduct, fetchRatingForProduct } from "@core/data/reviews"
7
+
8
+ import { retrieveCustomer } from "@core/data/customer"
9
+ import LoginPopup from "@modules/common/components/login-popup"
10
+ import { useParams } from "next/navigation"
11
+
12
+ type ProductRatingProps = {
13
+ product: HttpTypes.StoreProduct & {
14
+ average_rating?: number | null
15
+ total_rating_count?: number | null
16
+ }
17
+ showButton?: boolean
18
+ buttonText?: string
19
+ showStars?: boolean
20
+ }
21
+
22
+ export default function ProductRating({
23
+ product,
24
+ showButton = true,
25
+ buttonText = "Rate this",
26
+ showStars = true
27
+ }: ProductRatingProps) {
28
+ const [isReviewOpen, setIsReviewOpen] = useState(false)
29
+ const [reviews, setReviews] = useState<any[]>([])
30
+ const [ratingSummary, setRatingSummary] = useState<{ average_rating: number, total_reviews: number } | null>(null)
31
+ const [showLoginPopup, setShowLoginPopup] = useState(false)
32
+ const [isCheckingAuth, setIsCheckingAuth] = useState(false)
33
+ const { countryCode } = useParams() as { countryCode: string }
34
+
35
+ const fetchReviewsAndStatus = async () => {
36
+ try {
37
+ const [fetchedReviews, fetchedSummary] = await Promise.all([
38
+ fetchReviewsForProduct(product.id),
39
+ fetchRatingForProduct(product.id)
40
+ ])
41
+ setReviews(fetchedReviews)
42
+ setRatingSummary(fetchedSummary)
43
+ } catch (error) {
44
+ // Silence error
45
+ }
46
+ }
47
+
48
+ useEffect(() => {
49
+ fetchReviewsAndStatus()
50
+ }, [product.id])
51
+
52
+ // Use pre-calculated summary from backend
53
+ const averageRating = useMemo(() => {
54
+ return ratingSummary?.average_rating ?? product.average_rating ?? 0
55
+ }, [ratingSummary, product.average_rating])
56
+
57
+ const totalReviews = ratingSummary?.total_reviews ?? (product.total_rating_count || 0)
58
+
59
+ const handleRateClick = async () => {
60
+ setIsCheckingAuth(true)
61
+ try {
62
+ const customer = await retrieveCustomer()
63
+ if (customer) {
64
+ setIsReviewOpen(true)
65
+ } else {
66
+ setShowLoginPopup(true)
67
+ }
68
+ } catch (error) {
69
+ // Fallback to showing login popup on error
70
+ setShowLoginPopup(true)
71
+ } finally {
72
+ setIsCheckingAuth(false)
73
+ }
74
+ }
75
+
76
+ return (
77
+ <>
78
+ <div className="flex items-center gap-2">
79
+ {showStars && totalReviews > 0 && (
80
+ <div className="flex items-center gap-1 cursor-pointer" onClick={handleRateClick}>
81
+ <div className="flex">
82
+ {[1, 2, 3, 4, 5].map((star) => {
83
+ const isFilled = star <= averageRating
84
+ const isHalfFilled = star > averageRating && star - 0.5 <= averageRating
85
+
86
+ return (
87
+ <div key={star} className="relative" style={{ width: '20px', height: '20px' }}>
88
+ <svg
89
+ width="20"
90
+ height="20"
91
+ viewBox="0 0 24 24"
92
+ fill="none"
93
+ stroke={isFilled || isHalfFilled ? (averageRating >= 4 ? "#22c55e" : averageRating >= 3 ? "#FFD700" : "#ef4444") : "#D1D5DB"}
94
+ strokeWidth="2"
95
+ >
96
+ <polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"></polygon>
97
+ </svg>
98
+ {isFilled && (
99
+ <svg
100
+ width="20"
101
+ height="20"
102
+ viewBox="0 0 24 24"
103
+ fill={averageRating >= 4 ? "#22c55e" : averageRating >= 3 ? "#FFD700" : "#ef4444"}
104
+ stroke={averageRating >= 4 ? "#22c55e" : averageRating >= 3 ? "#FFD700" : "#ef4444"}
105
+ strokeWidth="2"
106
+ className="absolute top-0 left-0"
107
+ >
108
+ <polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"></polygon>
109
+ </svg>
110
+ )}
111
+ {isHalfFilled && (
112
+ <svg
113
+ width="20"
114
+ height="20"
115
+ viewBox="0 0 24 24"
116
+ fill={averageRating >= 4 ? "#22c55e" : averageRating >= 3 ? "#FFD700" : "#ef4444"}
117
+ stroke={averageRating >= 4 ? "#22c55e" : averageRating >= 3 ? "#FFD700" : "#ef4444"}
118
+ strokeWidth="2"
119
+ className="absolute top-0 left-0"
120
+ style={{ clipPath: 'inset(0 50% 0 0)' }}
121
+ >
122
+ <polygon points="12 2 15.09 8.26 22 9.27 17 14.14 18.18 21.02 12 17.77 5.82 21.02 7 14.14 2 9.27 8.91 8.26 12 2"></polygon>
123
+ </svg>
124
+ )}
125
+ </div>
126
+ )
127
+ })}
128
+ </div>
129
+ {averageRating > 0 && (
130
+ <span className="text-sm text-gray-700 font-medium">
131
+ ({averageRating.toFixed(1)})
132
+ </span>
133
+ )}
134
+ </div>
135
+ )}
136
+ {showButton && (
137
+ <div className="relative group/ratingbtn">
138
+ <button
139
+ onClick={handleRateClick}
140
+ disabled={isCheckingAuth}
141
+ className="flex items-center gap-1.5 px-3 py-1.5 rounded-full border text-xs sm:text-sm font-bold transition-all duration-200 border-[#8B5AB1]/20 bg-[#8B5AB1]/5 text-[#8B5AB1] hover:bg-[#8B5AB1] hover:text-white hover:shadow-md hover:shadow-purple-100 active:scale-95 disabled:opacity-50 disabled:cursor-wait"
142
+ >
143
+ {isCheckingAuth ? (
144
+ <span className="w-4 h-4 border-2 border-current border-t-transparent rounded-full animate-spin"></span>
145
+ ) : (
146
+ <svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" strokeWidth="2.5" strokeLinecap="round" strokeLinejoin="round">
147
+ <path d="M12 20h9" /><path d="M16.5 3.5a2.121 2.121 0 0 1 3 3L7 19l-4 1 1-4L16.5 3.5z" />
148
+ </svg>
149
+ )}
150
+ {buttonText}
151
+ </button>
152
+ </div>
153
+ )}
154
+ </div>
155
+
156
+ <ReviewModal
157
+ productId={product.id}
158
+ productTitle={product.title || "Product"}
159
+ isOpen={isReviewOpen}
160
+ close={() => setIsReviewOpen(false)}
161
+ onSuccess={fetchReviewsAndStatus}
162
+ />
163
+
164
+ <LoginPopup
165
+ isOpen={showLoginPopup}
166
+ onClose={() => setShowLoginPopup(false)}
167
+ countryCode={countryCode}
168
+ message="Please login to submit a review for this product."
169
+ />
170
+ </>
171
+ )
172
+ }