@alphasquad/saleor-template-advance 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (441) hide show
  1. package/.env.example +57 -0
  2. package/APPLE_PAY_QUICK_START.md +165 -0
  3. package/APPLE_PAY_SETUP.md +331 -0
  4. package/README.md +46 -0
  5. package/SEO_AUDIT_CHECKLIST_STATUS.md +244 -0
  6. package/SEO_AUDIT_REPORT.md +66 -0
  7. package/eslint.config.mjs +16 -0
  8. package/next-env.d.ts +5 -0
  9. package/next.config.ts +109 -0
  10. package/package.json +47 -0
  11. package/postcss.config.mjs +5 -0
  12. package/public/.well-known/apple-developer-merchantid-domain-association +1 -0
  13. package/public/Logo.png +0 -0
  14. package/public/brand-video.mp4 +0 -0
  15. package/public/favicon.ico +0 -0
  16. package/public/file.svg +1 -0
  17. package/public/footer/facebook.tsx +34 -0
  18. package/public/footer/instagram.tsx +27 -0
  19. package/public/footer/mail.tsx +5 -0
  20. package/public/footer/x.tsx +35 -0
  21. package/public/globe.svg +1 -0
  22. package/public/icons/Authorize.net.webp +0 -0
  23. package/public/icons/amex.gif +0 -0
  24. package/public/icons/appIcon.png +0 -0
  25. package/public/icons/discover.gif +0 -0
  26. package/public/icons/master.gif +0 -0
  27. package/public/icons/paypal.png +0 -0
  28. package/public/icons/stripe.png +0 -0
  29. package/public/icons/visa.gif +0 -0
  30. package/public/images/BackgroundNoise.png +0 -0
  31. package/public/images/footer-background.png +0 -0
  32. package/public/next.svg +1 -0
  33. package/public/no-image-avail-large.png +0 -0
  34. package/public/random-car-1.jpeg +0 -0
  35. package/public/random-car-2.png +0 -0
  36. package/public/random-car-3.jpg +0 -0
  37. package/public/random-car-4.jpg +0 -0
  38. package/public/random-car-5.jpg +0 -0
  39. package/public/star.svg +3 -0
  40. package/public/vercel.svg +1 -0
  41. package/public/window.svg +1 -0
  42. package/scripts/seo-audit/generate-checklist.mjs +156 -0
  43. package/src/app/(auth)/account/forgot-password/layout.tsx +16 -0
  44. package/src/app/(auth)/account/forgot-password/page.tsx +135 -0
  45. package/src/app/(auth)/account/login/layout.tsx +16 -0
  46. package/src/app/(auth)/account/login/page.tsx +288 -0
  47. package/src/app/(auth)/account/otp/layout.tsx +16 -0
  48. package/src/app/(auth)/account/otp/page.tsx +108 -0
  49. package/src/app/(auth)/account/register/layout.tsx +16 -0
  50. package/src/app/(auth)/account/register/page.tsx +431 -0
  51. package/src/app/(auth)/account/reset-password/layout.tsx +16 -0
  52. package/src/app/(auth)/account/reset-password/page.tsx +222 -0
  53. package/src/app/[slug]/page.tsx +43 -0
  54. package/src/app/about/loading.tsx +17 -0
  55. package/src/app/about/page.tsx +61 -0
  56. package/src/app/account/address/layout.tsx +15 -0
  57. package/src/app/account/address/page.tsx +166 -0
  58. package/src/app/account/head.tsx +4 -0
  59. package/src/app/account/layout.tsx +62 -0
  60. package/src/app/account/orders/[id]/layout.tsx +17 -0
  61. package/src/app/account/orders/[id]/page.tsx +115 -0
  62. package/src/app/account/orders/components/orderDetailsModal.tsx +410 -0
  63. package/src/app/account/orders/layout.tsx +15 -0
  64. package/src/app/account/orders/page.tsx +146 -0
  65. package/src/app/account/page.tsx +39 -0
  66. package/src/app/account/settings/components/editProfileSuccessModal.tsx +28 -0
  67. package/src/app/account/settings/layout.tsx +15 -0
  68. package/src/app/account/settings/page.tsx +260 -0
  69. package/src/app/api/affirm/check-status/route.ts +94 -0
  70. package/src/app/api/affirm/create-checkout/route.ts +109 -0
  71. package/src/app/api/affirm/get-config/route.ts +108 -0
  72. package/src/app/api/affirm/process-payment/route.ts +244 -0
  73. package/src/app/api/affirm/test-connection/route.ts +45 -0
  74. package/src/app/api/auth/clear/route.ts +16 -0
  75. package/src/app/api/auth/clear-cookies/route.ts +42 -0
  76. package/src/app/api/auth/set/route.ts +47 -0
  77. package/src/app/api/configuration/route.ts +18 -0
  78. package/src/app/api/dynamic-page/[slug]/route.ts +24 -0
  79. package/src/app/api/form-submission/route.ts +237 -0
  80. package/src/app/api/paypal/capture-order/route.ts +303 -0
  81. package/src/app/api/paypal/create-order/route.ts +211 -0
  82. package/src/app/api/paypal/get-config/route.ts +240 -0
  83. package/src/app/api/search-proxy/route.ts +52 -0
  84. package/src/app/authorize-net-success/layout.tsx +19 -0
  85. package/src/app/authorize-net-success/page.tsx +12 -0
  86. package/src/app/authorize-net-success/summary.tsx +486 -0
  87. package/src/app/blog/[slug]/blogContentRenderer.tsx +369 -0
  88. package/src/app/blog/[slug]/layout.tsx +17 -0
  89. package/src/app/blog/[slug]/page.tsx +151 -0
  90. package/src/app/blog/constant.tsx +147 -0
  91. package/src/app/blog/layout.tsx +31 -0
  92. package/src/app/blog/page.tsx +81 -0
  93. package/src/app/brand/[id]/BrandPageClient.tsx +188 -0
  94. package/src/app/brand/[id]/layout.tsx +17 -0
  95. package/src/app/brand/[id]/page.tsx +176 -0
  96. package/src/app/brands/components/brandsListingClient.tsx +97 -0
  97. package/src/app/brands/layout.tsx +31 -0
  98. package/src/app/brands/page.tsx +40 -0
  99. package/src/app/cancellation-policy/page.tsx +53 -0
  100. package/src/app/cart/layout.tsx +19 -0
  101. package/src/app/cart/page.tsx +752 -0
  102. package/src/app/category/[slug]/CategoryPageClient.tsx +377 -0
  103. package/src/app/category/[slug]/layout.tsx +17 -0
  104. package/src/app/category/[slug]/page.tsx +224 -0
  105. package/src/app/category/page.tsx +114 -0
  106. package/src/app/checkout/components/addNewAddressModal.tsx +474 -0
  107. package/src/app/checkout/layout.tsx +19 -0
  108. package/src/app/checkout/page.tsx +3312 -0
  109. package/src/app/components/account/AccountTabs.tsx +40 -0
  110. package/src/app/components/ads/GoogleAdSense.tsx +74 -0
  111. package/src/app/components/analytics/AnalyticsScripts.tsx +78 -0
  112. package/src/app/components/analytics/ConditionalGTMNoscript.tsx +24 -0
  113. package/src/app/components/analytics/ConditionalGoogleAnalytics.tsx +16 -0
  114. package/src/app/components/ancillary/AncillaryContent.tsx +7 -0
  115. package/src/app/components/auth/TokenExpirationHandler.tsx +8 -0
  116. package/src/app/components/blog/BlogList.tsx +112 -0
  117. package/src/app/components/checkout/AddressInformationSection.tsx +34 -0
  118. package/src/app/components/checkout/AddressManagement.tsx +571 -0
  119. package/src/app/components/checkout/CheckoutHeader.tsx +51 -0
  120. package/src/app/components/checkout/CheckoutQuestions.tsx +454 -0
  121. package/src/app/components/checkout/CheckoutTermsModal.tsx +81 -0
  122. package/src/app/components/checkout/ContactDetailsSection.tsx +52 -0
  123. package/src/app/components/checkout/DealerShippingSection.tsx +359 -0
  124. package/src/app/components/checkout/DeliveryMethodSection.tsx +249 -0
  125. package/src/app/components/checkout/OrderSummary.tsx +386 -0
  126. package/src/app/components/checkout/TermsContentRenderer.tsx +147 -0
  127. package/src/app/components/checkout/WillCallSection.tsx +133 -0
  128. package/src/app/components/checkout/affirmPayment.tsx +383 -0
  129. package/src/app/components/checkout/checkoutProcessingModal.tsx +96 -0
  130. package/src/app/components/checkout/googlePayButton.tsx +334 -0
  131. package/src/app/components/checkout/paymentStep.tsx +180 -0
  132. package/src/app/components/checkout/paypalPayment.tsx +1083 -0
  133. package/src/app/components/checkout/saleorNativePayment.tsx +1758 -0
  134. package/src/app/components/dynamicPage/DynamicPageRenderer.tsx +13 -0
  135. package/src/app/components/dynamicPage/HtmlWidgetRenderer.tsx +144 -0
  136. package/src/app/components/filtersCollapsible/index.tsx +365 -0
  137. package/src/app/components/globalSearch/index.tsx +423 -0
  138. package/src/app/components/layout/cartDropDown.tsx +628 -0
  139. package/src/app/components/layout/components/FooterNewsletter.tsx +21 -0
  140. package/src/app/components/layout/footer.tsx +283 -0
  141. package/src/app/components/layout/header/accountMenuDropdown.tsx +53 -0
  142. package/src/app/components/layout/header/components/CartBadge.tsx +18 -0
  143. package/src/app/components/layout/header/components/LoadingState.tsx +17 -0
  144. package/src/app/components/layout/header/components/MenuItemDropdown.tsx +124 -0
  145. package/src/app/components/layout/header/components/MobileNavbar.tsx +123 -0
  146. package/src/app/components/layout/header/components/NavbarActions.tsx +125 -0
  147. package/src/app/components/layout/header/components/NavbarBrand.tsx +29 -0
  148. package/src/app/components/layout/header/components/NavigationLinks.tsx +131 -0
  149. package/src/app/components/layout/header/hamMenuSlide.tsx +318 -0
  150. package/src/app/components/layout/header/header.tsx +44 -0
  151. package/src/app/components/layout/header/hooks/useDropdown.ts +45 -0
  152. package/src/app/components/layout/header/hooks/useNavbarData.ts +138 -0
  153. package/src/app/components/layout/header/hooks/useNavbarState.ts +66 -0
  154. package/src/app/components/layout/header/megaMenuDropdown.tsx +116 -0
  155. package/src/app/components/layout/header/navBar.tsx +121 -0
  156. package/src/app/components/layout/header/search.tsx +418 -0
  157. package/src/app/components/layout/header/styles/navbarStyles.ts +27 -0
  158. package/src/app/components/layout/header/topBar.tsx +214 -0
  159. package/src/app/components/layout/joinNewsletterForm/index.tsx +72 -0
  160. package/src/app/components/layout/mobileAccordian/index.tsx +92 -0
  161. package/src/app/components/layout/paymentMethods.tsx +75 -0
  162. package/src/app/components/layout/rootLayout.tsx +23 -0
  163. package/src/app/components/layout/siteInfo.tsx +103 -0
  164. package/src/app/components/layout/socialLinks.tsx +65 -0
  165. package/src/app/components/newsletterSection/emailListSection.tsx +224 -0
  166. package/src/app/components/newsletterSection/emailSectionServer.tsx +8 -0
  167. package/src/app/components/providers/ApolloWrapper.tsx +12 -0
  168. package/src/app/components/providers/AppConfigurationProvider.tsx +108 -0
  169. package/src/app/components/providers/GoogleAnalyticsProvider.tsx +149 -0
  170. package/src/app/components/providers/GoogleTagManagerProvider.tsx +31 -0
  171. package/src/app/components/providers/RecaptchaProvider.tsx +18 -0
  172. package/src/app/components/providers/ServerAppConfigurationProvider.tsx +133 -0
  173. package/src/app/components/providers/YMMStatusProvider.tsx +15 -0
  174. package/src/app/components/reuseableUI/AboutUs.tsx +115 -0
  175. package/src/app/components/reuseableUI/AddToCartClient.tsx +125 -0
  176. package/src/app/components/reuseableUI/EditorJsRenderer.tsx +219 -0
  177. package/src/app/components/reuseableUI/HeroSectionsearchByVehicle.tsx +188 -0
  178. package/src/app/components/reuseableUI/ImageWithFallback.tsx +41 -0
  179. package/src/app/components/reuseableUI/Toast.tsx +101 -0
  180. package/src/app/components/reuseableUI/blogCard.tsx +52 -0
  181. package/src/app/components/reuseableUI/brandCard.tsx +68 -0
  182. package/src/app/components/reuseableUI/breadcrumb.tsx +38 -0
  183. package/src/app/components/reuseableUI/categoryCard.tsx +37 -0
  184. package/src/app/components/reuseableUI/categorySkeleton.tsx +31 -0
  185. package/src/app/components/reuseableUI/commonButton.tsx +48 -0
  186. package/src/app/components/reuseableUI/defaultInputField/index.tsx +84 -0
  187. package/src/app/components/reuseableUI/emptyState.tsx +29 -0
  188. package/src/app/components/reuseableUI/errorTag.tsx +15 -0
  189. package/src/app/components/reuseableUI/heading/index.tsx +20 -0
  190. package/src/app/components/reuseableUI/input.tsx +117 -0
  191. package/src/app/components/reuseableUI/listCard.tsx +137 -0
  192. package/src/app/components/reuseableUI/loadingUI.tsx +12 -0
  193. package/src/app/components/reuseableUI/modalLayout.tsx +76 -0
  194. package/src/app/components/reuseableUI/newsletter/newsletterClient.tsx +622 -0
  195. package/src/app/components/reuseableUI/newsletter/newslettersHomeModal.tsx +68 -0
  196. package/src/app/components/reuseableUI/offerCard.tsx +42 -0
  197. package/src/app/components/reuseableUI/passwordRules/passwordRules.tsx +56 -0
  198. package/src/app/components/reuseableUI/primaryButton/index.tsx +34 -0
  199. package/src/app/components/reuseableUI/productCard.tsx +118 -0
  200. package/src/app/components/reuseableUI/productSkeleton.tsx +34 -0
  201. package/src/app/components/reuseableUI/searchByVehicle.tsx +187 -0
  202. package/src/app/components/reuseableUI/secondaryButton/index.tsx +34 -0
  203. package/src/app/components/reuseableUI/section.tsx +20 -0
  204. package/src/app/components/reuseableUI/select/index.tsx +98 -0
  205. package/src/app/components/reuseableUI/skeletonLoader.tsx +117 -0
  206. package/src/app/components/reuseableUI/statusTag.tsx +24 -0
  207. package/src/app/components/reuseableUI/tags/saleTag.tsx +19 -0
  208. package/src/app/components/reuseableUI/testimonialCard.tsx +93 -0
  209. package/src/app/components/richText/EditorRenderer.tsx +318 -0
  210. package/src/app/components/search/HierarchicalCategoryFilter.tsx +155 -0
  211. package/src/app/components/search/SearchFilters.tsx +155 -0
  212. package/src/app/components/search/YMMSearchSidebar.tsx +187 -0
  213. package/src/app/components/seo/ServerProductCard.tsx +91 -0
  214. package/src/app/components/seo/ServerProductGrid.tsx +45 -0
  215. package/src/app/components/shop/CategoryFilter.tsx +184 -0
  216. package/src/app/components/shop/ItemsPerPageSelect.tsx +69 -0
  217. package/src/app/components/shop/ItemsPerPageSelectClient.tsx +58 -0
  218. package/src/app/components/shop/MobileFilters.tsx +103 -0
  219. package/src/app/components/shop/ProductGridSkeleton.tsx +16 -0
  220. package/src/app/components/shop/ProductsGrid.tsx +230 -0
  221. package/src/app/components/shop/SearchFilter.tsx +218 -0
  222. package/src/app/components/shop/SearchFilterClient.tsx +122 -0
  223. package/src/app/components/shop/SearchLoadingOverlay.tsx +32 -0
  224. package/src/app/components/shop/ShopMobileFilters.tsx +205 -0
  225. package/src/app/components/showroom/VehicleSearchDropdowns.tsx +187 -0
  226. package/src/app/components/showroom/brandsSwiper.tsx +49 -0
  227. package/src/app/components/showroom/brandsSwiperClient copy.tsx +93 -0
  228. package/src/app/components/showroom/brandsSwiperClient.tsx +122 -0
  229. package/src/app/components/showroom/brandsSwiperServer.tsx +42 -0
  230. package/src/app/components/showroom/bundleProducts.tsx +120 -0
  231. package/src/app/components/showroom/categoryGrid.tsx +51 -0
  232. package/src/app/components/showroom/categoryGridServer.tsx +45 -0
  233. package/src/app/components/showroom/categorySwiper.tsx +115 -0
  234. package/src/app/components/showroom/featureStrip.tsx +139 -0
  235. package/src/app/components/showroom/offersSwiper.tsx +181 -0
  236. package/src/app/components/showroom/productGrid.tsx +56 -0
  237. package/src/app/components/showroom/productSwiper.tsx +119 -0
  238. package/src/app/components/showroom/promotion-slider.tsx +138 -0
  239. package/src/app/components/showroom/promotion.tsx +207 -0
  240. package/src/app/components/showroom/promotionsSwiper.tsx +174 -0
  241. package/src/app/components/showroom/showroomHeroCarousel.tsx +141 -0
  242. package/src/app/components/showroom/testimonialsGrid.tsx +106 -0
  243. package/src/app/components/skeletons/ContentSkeleton.tsx +14 -0
  244. package/src/app/components/sortDropdown/index.tsx +116 -0
  245. package/src/app/components/tertiaryButton/index.tsx +25 -0
  246. package/src/app/components/theme/theme-provider.tsx +82 -0
  247. package/src/app/contact/layout.tsx +32 -0
  248. package/src/app/contact/page.tsx +591 -0
  249. package/src/app/content/[slug]/layout.tsx +17 -0
  250. package/src/app/content/[slug]/page.tsx +159 -0
  251. package/src/app/content/layout.tsx +31 -0
  252. package/src/app/content/page.tsx +88 -0
  253. package/src/app/core-policies/page.tsx +55 -0
  254. package/src/app/discounts/page.tsx +54 -0
  255. package/src/app/frequently-asked-questions/page.tsx +57 -0
  256. package/src/app/globals.css +440 -0
  257. package/src/app/hooks/useDealerLocations.ts +259 -0
  258. package/src/app/hooks/useGTMEngagement.ts +71 -0
  259. package/src/app/hooks/useGoogleAnalytics.ts +145 -0
  260. package/src/app/layout.tsx +149 -0
  261. package/src/app/not-found.tsx +31 -0
  262. package/src/app/order-confirmation/layout.tsx +19 -0
  263. package/src/app/order-confirmation/page.tsx +12 -0
  264. package/src/app/order-confirmation/summary.tsx +1775 -0
  265. package/src/app/page.tsx +194 -0
  266. package/src/app/privacy-policy/loading.tsx +17 -0
  267. package/src/app/privacy-policy/page.tsx +56 -0
  268. package/src/app/product/[id]/ProductDetailClient.tsx +2448 -0
  269. package/src/app/product/[id]/components/itemInquiryModal.tsx +461 -0
  270. package/src/app/product/[id]/layout.tsx +116 -0
  271. package/src/app/product/[id]/page.tsx +200 -0
  272. package/src/app/product/layout.tsx +15 -0
  273. package/src/app/products/all/AllProductsClient.tsx +743 -0
  274. package/src/app/products/all/page.tsx +176 -0
  275. package/src/app/products/components/shopEmptyState.tsx +29 -0
  276. package/src/app/request-return/layout.tsx +36 -0
  277. package/src/app/request-return/page.tsx +597 -0
  278. package/src/app/robots.txt/route.ts +27 -0
  279. package/src/app/search/layout.tsx +16 -0
  280. package/src/app/search/page.tsx +736 -0
  281. package/src/app/shipping-returns/page.tsx +60 -0
  282. package/src/app/site-map/layout.tsx +33 -0
  283. package/src/app/site-map/page.tsx +113 -0
  284. package/src/app/sitemap-index.xml/route.ts +20 -0
  285. package/src/app/sitemap.ts +10 -0
  286. package/src/app/terms-and-conditions/loading.tsx +17 -0
  287. package/src/app/terms-and-conditions/page.tsx +56 -0
  288. package/src/app/utils/appConfiguration.ts +327 -0
  289. package/src/app/utils/branding.ts +52 -0
  290. package/src/app/utils/configurationService.ts +202 -0
  291. package/src/app/utils/constant.tsx +242 -0
  292. package/src/app/utils/editorJsUtils.tsx +249 -0
  293. package/src/app/utils/functions.ts +146 -0
  294. package/src/app/utils/googleAnalytics.ts +168 -0
  295. package/src/app/utils/googleTagManager.ts +475 -0
  296. package/src/app/utils/ipDetection.ts +270 -0
  297. package/src/app/utils/serverConfigurationService.ts +209 -0
  298. package/src/app/utils/svgs/GridIcon.tsx +45 -0
  299. package/src/app/utils/svgs/account/myAccount/listDotIcon.tsx +3 -0
  300. package/src/app/utils/svgs/account/myAccount/tickIcon.tsx +10 -0
  301. package/src/app/utils/svgs/account/orderHistory/InfoIcon.tsx +49 -0
  302. package/src/app/utils/svgs/arrowDownIcon.tsx +17 -0
  303. package/src/app/utils/svgs/arrowIcon.tsx +25 -0
  304. package/src/app/utils/svgs/arrowUpIcon.tsx +16 -0
  305. package/src/app/utils/svgs/brandsSearchIcon.tsx +25 -0
  306. package/src/app/utils/svgs/cart/cartIcon.tsx +31 -0
  307. package/src/app/utils/svgs/cart/plusIcon.tsx +13 -0
  308. package/src/app/utils/svgs/cart/subtractIcon.tsx +13 -0
  309. package/src/app/utils/svgs/cart/successTickIcon.tsx +14 -0
  310. package/src/app/utils/svgs/chevronDownIcon.tsx +21 -0
  311. package/src/app/utils/svgs/closeEyeIcon.tsx +47 -0
  312. package/src/app/utils/svgs/crossIcon.tsx +25 -0
  313. package/src/app/utils/svgs/eyeIcon.tsx +29 -0
  314. package/src/app/utils/svgs/featureTag.tsx +20 -0
  315. package/src/app/utils/svgs/filterIcon.tsx +3 -0
  316. package/src/app/utils/svgs/globleIcon.tsx +41 -0
  317. package/src/app/utils/svgs/infoIcon.tsx +34 -0
  318. package/src/app/utils/svgs/listIcon.tsx +50 -0
  319. package/src/app/utils/svgs/logOutIcon.tsx +35 -0
  320. package/src/app/utils/svgs/menuIcon.tsx +8 -0
  321. package/src/app/utils/svgs/minusIcon.tsx +18 -0
  322. package/src/app/utils/svgs/newsletterIcon.tsx +19 -0
  323. package/src/app/utils/svgs/noDataFoundIcon-.tsx +26 -0
  324. package/src/app/utils/svgs/noProductFoundIcon.tsx +43 -0
  325. package/src/app/utils/svgs/passwordIcons/errorIcon.tsx +31 -0
  326. package/src/app/utils/svgs/passwordIcons/successIcon.tsx +24 -0
  327. package/src/app/utils/svgs/paymentProcessingIcons/hourglassIcon.tsx +43 -0
  328. package/src/app/utils/svgs/paymentProcessingIcons/modalCrossIcon.tsx +23 -0
  329. package/src/app/utils/svgs/paymentProcessingIcons/paymentFailedIcon.tsx +47 -0
  330. package/src/app/utils/svgs/pencilIcon.tsx +11 -0
  331. package/src/app/utils/svgs/plusIcon.tsx +25 -0
  332. package/src/app/utils/svgs/productInquiryIcon.tsx +40 -0
  333. package/src/app/utils/svgs/searchIcon.tsx +31 -0
  334. package/src/app/utils/svgs/shoppingCart.tsx +32 -0
  335. package/src/app/utils/svgs/spinnerIcon.tsx +22 -0
  336. package/src/app/utils/svgs/spinnerLoadingIcon.tsx +26 -0
  337. package/src/app/utils/svgs/successTickIcon.tsx +40 -0
  338. package/src/app/utils/svgs/swiperArrowIconLeft.tsx +18 -0
  339. package/src/app/utils/svgs/swiperArrowIconRight.tsx +18 -0
  340. package/src/app/utils/svgs/userProfileIcon.tsx +31 -0
  341. package/src/app/utils/svgs/warningCircleIcon.tsx +15 -0
  342. package/src/app/warranty/constant.tsx +63 -0
  343. package/src/app/warranty/loading.tsx +17 -0
  344. package/src/app/warranty/page.tsx +56 -0
  345. package/src/graphql/client.ts +288 -0
  346. package/src/graphql/mutations/accountAddressCreate.ts +56 -0
  347. package/src/graphql/mutations/accountAddressDelete.ts +23 -0
  348. package/src/graphql/mutations/accountAddressUpdate.ts +55 -0
  349. package/src/graphql/mutations/accountSetDefaultAddress.ts +32 -0
  350. package/src/graphql/mutations/accountUpdate.ts +34 -0
  351. package/src/graphql/mutations/changePassword.ts +25 -0
  352. package/src/graphql/mutations/checkout.ts +117 -0
  353. package/src/graphql/mutations/checkoutAddVoucher.ts +63 -0
  354. package/src/graphql/mutations/checkoutComplete.ts +79 -0
  355. package/src/graphql/mutations/checkoutCreate.ts +131 -0
  356. package/src/graphql/mutations/checkoutCustomerAttach.ts +50 -0
  357. package/src/graphql/mutations/checkoutEmailUpdate.ts +15 -0
  358. package/src/graphql/mutations/checkoutLineMetadataUpdate.ts +52 -0
  359. package/src/graphql/mutations/checkoutPaymentCreate.ts +82 -0
  360. package/src/graphql/mutations/paymentGatewayInitialize.ts +58 -0
  361. package/src/graphql/mutations/registerAccount.ts +65 -0
  362. package/src/graphql/mutations/requestPasswordReset.ts +32 -0
  363. package/src/graphql/mutations/setPassword.ts +49 -0
  364. package/src/graphql/mutations/signIn.ts +50 -0
  365. package/src/graphql/mutations/tokenRefresh.ts +19 -0
  366. package/src/graphql/mutations/updateCheckoutMetadata.ts +49 -0
  367. package/src/graphql/mutations/updateProfile.ts +18 -0
  368. package/src/graphql/mutations/willCallDeliveryMethod.ts +81 -0
  369. package/src/graphql/queries/checkout.ts +168 -0
  370. package/src/graphql/queries/findProductByOldSlug.ts +58 -0
  371. package/src/graphql/queries/getAboutPage.ts +24 -0
  372. package/src/graphql/queries/getAboutPageId.ts +9 -0
  373. package/src/graphql/queries/getAboutUs.ts +38 -0
  374. package/src/graphql/queries/getAddressInformation.ts +38 -0
  375. package/src/graphql/queries/getAllCategories.ts +41 -0
  376. package/src/graphql/queries/getAllCategoriesTree.ts +67 -0
  377. package/src/graphql/queries/getAllCategoriesWithProducts.ts +29 -0
  378. package/src/graphql/queries/getAllCollectionsWithProducts.ts +16 -0
  379. package/src/graphql/queries/getBlogs.ts +222 -0
  380. package/src/graphql/queries/getBrands.ts +17 -0
  381. package/src/graphql/queries/getBundles.ts +43 -0
  382. package/src/graphql/queries/getCategories.ts +20 -0
  383. package/src/graphql/queries/getChannels.ts +77 -0
  384. package/src/graphql/queries/getCheckoutQuestions.ts +115 -0
  385. package/src/graphql/queries/getCheckoutTermsAndConditions.ts +37 -0
  386. package/src/graphql/queries/getContactPage.ts +117 -0
  387. package/src/graphql/queries/getContentPage.ts +191 -0
  388. package/src/graphql/queries/getDiscountOffers.ts +18 -0
  389. package/src/graphql/queries/getDynamicPageBySlug.ts +251 -0
  390. package/src/graphql/queries/getFeaturedProducts.ts +48 -0
  391. package/src/graphql/queries/getHeroMetadata.ts +23 -0
  392. package/src/graphql/queries/getMenuBySlug.ts +84 -0
  393. package/src/graphql/queries/getMyProfile.ts +23 -0
  394. package/src/graphql/queries/getNewsletter.ts +122 -0
  395. package/src/graphql/queries/getNewsletterPage.ts +111 -0
  396. package/src/graphql/queries/getPageBySlug.ts +52 -0
  397. package/src/graphql/queries/getPageTypeId.ts +27 -0
  398. package/src/graphql/queries/getPaymentMethods.ts +61 -0
  399. package/src/graphql/queries/getProducts.ts +78 -0
  400. package/src/graphql/queries/getPromotions.ts +24 -0
  401. package/src/graphql/queries/getRequestReturnPage.ts +121 -0
  402. package/src/graphql/queries/getSiteInfo.ts +54 -0
  403. package/src/graphql/queries/getSocialLinks.ts +52 -0
  404. package/src/graphql/queries/getTestimonials.ts +25 -0
  405. package/src/graphql/queries/getUserWithCheckout.ts +27 -0
  406. package/src/graphql/queries/getVehicleMakes.ts +21 -0
  407. package/src/graphql/queries/getVehicleModels.ts +21 -0
  408. package/src/graphql/queries/getVehicleYears.ts +21 -0
  409. package/src/graphql/queries/meAddresses.ts +56 -0
  410. package/src/graphql/queries/myOrders.ts +37 -0
  411. package/src/graphql/queries/orderDetail.ts +231 -0
  412. package/src/graphql/queries/productDetailsById.ts +197 -0
  413. package/src/graphql/queries/productInquiry.ts +115 -0
  414. package/src/graphql/queries/productsByCategoriesAndCollections.ts +39 -0
  415. package/src/graphql/queries/willCallCollectionPoints.ts +55 -0
  416. package/src/graphql/server-client.ts +54 -0
  417. package/src/graphql/types/categories.ts +9 -0
  418. package/src/graphql/types/checkout.ts +168 -0
  419. package/src/graphql/types/offer.ts +12 -0
  420. package/src/graphql/types/product.ts +44 -0
  421. package/src/hooks/scrollPageTop.ts +9 -0
  422. package/src/hooks/serverNavbarData.ts +79 -0
  423. package/src/hooks/useCartSync.ts +24 -0
  424. package/src/hooks/useRecaptcha.ts +33 -0
  425. package/src/hooks/useTokenExpiration.ts +81 -0
  426. package/src/hooks/useVehicleData.ts +346 -0
  427. package/src/lib/api/kount.ts +165 -0
  428. package/src/lib/api/shop.ts +1445 -0
  429. package/src/lib/saleor/getSaleorApiUrl.ts +25 -0
  430. package/src/lib/schema.ts +303 -0
  431. package/src/lib/seo/extractTextFromEditorJs.ts +58 -0
  432. package/src/lib/seo/site.ts +10 -0
  433. package/src/lib/urls/normalizeInternalUrl.ts +53 -0
  434. package/src/middleware.ts +134 -0
  435. package/src/sitemaps/README.md +105 -0
  436. package/src/sitemaps/dynamic-pages-sitemap.ts +247 -0
  437. package/src/sitemaps/sitemap-index.ts +21 -0
  438. package/src/sitemaps/static-pages-sitemap.ts +36 -0
  439. package/src/store/useGlobalStore.tsx +1656 -0
  440. package/src/types/global.d.ts +148 -0
  441. package/tsconfig.json +27 -0
@@ -0,0 +1,117 @@
1
+ import React from "react";
2
+
3
+ interface SkeletonLoaderProps {
4
+ type?: "card" | "text" | "image" | "hero" | "category" | "product";
5
+ count?: number;
6
+ className?: string;
7
+ }
8
+
9
+ export const SkeletonLoader: React.FC<SkeletonLoaderProps> = ({
10
+ type = "card",
11
+ count = 1,
12
+ className,
13
+ }) => {
14
+ const renderSkeleton = () => {
15
+ switch (type) {
16
+ case "hero":
17
+ return (
18
+ <div
19
+ className={`relative flex lg:flex-row flex-col-reverse w-full md:h-[600px] bg-gray-200 ${
20
+ className ?? ""
21
+ }`}
22
+ >
23
+ <div className="lg:w-[min(500px,40%)] h-full bg-[var(--color-secondary-900)]">
24
+ <section
25
+ className="flex h-max flex-col w-full bg-[var(--color-secondary-900)] text-white px-6 py-8 lg:px-10 lg:py-12 lg:min-h-0 lg:justify-center"
26
+ aria-label="Find parts by vehicle Loading"
27
+ >
28
+ <div className="w-full max-w-md lg:max-w-none mx-auto lg:mx-0 space-y-4">
29
+ <h2 className="text-2xl md:text-3xl lg:text-4xl font-primary font-bold italic uppercase tracking-tight text-white">
30
+ FIND THE RIGHT PARTS
31
+ </h2>
32
+ <div
33
+ className="flex flex-col gap-4 w-full"
34
+ aria-label="Shop by differential, category, or brand Loading"
35
+ >
36
+ {Array.from({ length: 3 }).map((_, index) => (
37
+ <div
38
+ key={index}
39
+ className="flex flex-col w-full rounded-lg bg-[var(--color-secondary-800)] p-4 shadow-md border-b-[3px] border-b-[var(--color-primary)] h-[115px]"
40
+ >
41
+ <div className="flex items-center gap-2 mb-3">
42
+ <span
43
+ className="w-1 h-5 flex-shrink-0 rounded-full bg-[var(--color-primary)]"
44
+ aria-hidden
45
+ />
46
+ <span className="bg-white/70 w-full max-w-xs rounded animate-pulse h-5" />
47
+ </div>
48
+ <span className="bg-white/70 w-full rounded animate-pulse h-12" />
49
+ </div>
50
+ ))}
51
+ </div>
52
+ </div>
53
+ </section>
54
+ </div>
55
+ <div className="w-full md:max-w-[420px] h-[280px] md:h-[380px] bg-gray-300 lg:mr-5 animate-pulse" />
56
+ </div>
57
+ );
58
+
59
+ case "category":
60
+ return (
61
+ <div
62
+ className={`group block border border-gray-200 rounded-md overflow-hidden bg-white ${
63
+ className ?? ""
64
+ }`}
65
+ >
66
+ <div className="relative w-full h-[246px] bg-gray-200 animate-pulse">
67
+ <div className="absolute top-0 flex flex-col justify-between w-full h-full z-10 p-8">
68
+ <div className="h-16 w-full bg-gray-300 rounded "></div>
69
+ <div className="h-6 w-1/2 bg-gray-300 rounded "></div>
70
+ </div>
71
+ </div>
72
+ </div>
73
+ );
74
+
75
+ case "product":
76
+ return (
77
+ <div
78
+ className={`group block border border-gray-200 rounded-md overflow-hidden bg-white ${
79
+ className ?? ""
80
+ }`}
81
+ >
82
+ <div className="relative w-full h-48 bg-gray-200 animate-pulse" />
83
+ <div className="p-3">
84
+ <div className="h-4 bg-gray-200 rounded w-4/4 mb-2"></div>
85
+ <div className="h-4 bg-gray-200 rounded w-3/4 mb-2"></div>
86
+ <div className="h-3 bg-gray-200 rounded w-1/2 mb-2"></div>
87
+ <div className="h-4 bg-gray-200 rounded w-1/3"></div>
88
+ </div>
89
+ </div>
90
+ );
91
+
92
+ case "text":
93
+ return (
94
+ <div className="space-y-2">
95
+ <div className="h-4 bg-gray-200 rounded w-full"></div>
96
+ <div className="h-4 bg-gray-200 rounded w-5/6"></div>
97
+ <div className="h-4 bg-gray-200 rounded w-3/4"></div>
98
+ </div>
99
+ );
100
+
101
+ default:
102
+ return (
103
+ <div
104
+ className={`bg-gray-200 animate-pulse rounded ${className ?? ""}`}
105
+ />
106
+ );
107
+ }
108
+ };
109
+
110
+ return (
111
+ <>
112
+ {Array.from({ length: count }).map((_, index) => (
113
+ <React.Fragment key={index}>{renderSkeleton()}</React.Fragment>
114
+ ))}
115
+ </>
116
+ );
117
+ };
@@ -0,0 +1,24 @@
1
+ import { cn } from "@/app/utils/functions";
2
+
3
+ const StatusTag = ({ label, className }: { label: string; className?: string }) => {
4
+ const colorClasses =
5
+ {
6
+ delivered: "bg-green-800/10 text-green-800",
7
+ fulfilled: "bg-green-800/10 text-green-800",
8
+ draft: "bg-yellow-600/10 text-yellow-600 ring-yellow-600",
9
+ unfulfilled: "bg-yellow-600/10 text-yellow-600 ring-yellow-600",
10
+ unconfirmed: "bg-yellow-600/10 text-yellow-600 ring-yellow-600",
11
+ pending: "bg-yellow-400/10 text-yellow-400",
12
+ canceled: "bg-red-600/10 text-red-400",
13
+ expired: "bg-[var(--color-primary-600)]/10 text-[var(--color-primary-600)]",
14
+ }[label.toLowerCase()] || "bg-zinc-400/10 text-zinc-400";
15
+ return (
16
+ <div
17
+ className={cn("font-medium text-sm font-secondary tracking-[-0.25%] px-3.5 ring-1 w-fit py-0.5", colorClasses, className)}
18
+ >
19
+ {label}
20
+ </div>
21
+ );
22
+ };
23
+
24
+ export default StatusTag;
@@ -0,0 +1,19 @@
1
+ import React from "react";
2
+ interface tag {
3
+ content: string;
4
+ }
5
+ const SaleTag = ({ content }: tag) => {
6
+ return (
7
+ <div
8
+ style={{
9
+ backgroundColor: "var(--color-primary-600)",
10
+ color: "var(--color-secondary-100)",
11
+ }}
12
+ className="px-3 py-1"
13
+ >
14
+ {content}
15
+ </div>
16
+ );
17
+ };
18
+
19
+ export default SaleTag;
@@ -0,0 +1,93 @@
1
+ import Image from "next/image";
2
+
3
+ export interface TestimonialCardProps {
4
+ id: string;
5
+ title: string;
6
+ content: string;
7
+ author?: string;
8
+ rating?: number;
9
+ image?: string;
10
+ publishedAt: string;
11
+ }
12
+
13
+ export const TestimonialCard = ({
14
+ id,
15
+ title,
16
+ content,
17
+ author,
18
+ rating,
19
+ image,
20
+ publishedAt,
21
+ }: TestimonialCardProps) => {
22
+ return (
23
+ <div
24
+ key={id}
25
+ style={{ borderColor: "var(--color-secondary-220)" }}
26
+ className="bg-[var(--color-secondary-930)] p-8 shadow-sm border hover:shadow-md transition-shadow duration-300 h-full flex flex-col"
27
+ >
28
+ {/* Rating stars if provided */}
29
+ {rating && (
30
+ <div className="flex mb-4">
31
+ {[...Array(5)].map((_, index) => (
32
+ <svg
33
+ key={index}
34
+ style={{
35
+ color:
36
+ index < rating
37
+ ? "var(--color-primary-500)"
38
+ : "var(--color-secondary-300)",
39
+ }}
40
+ className="w-5 h-5"
41
+ fill="currentColor"
42
+ viewBox="0 0 20 20"
43
+ >
44
+ <path d="M9.049 2.927c.3-.921 1.603-.921 1.902 0l1.07 3.292a1 1 0 00.95.69h3.462c.969 0 1.371 1.24.588 1.81l-2.8 2.034a1 1 0 00-.364 1.118l1.07 3.292c.3.921-.755 1.688-1.54 1.118l-2.8-2.034a1 1 0 00-1.175 0l-2.8 2.034c-.784.57-1.838-.197-1.539-1.118l1.07-3.292a1 1 0 00-.364-1.118L2.98 8.72c-.783-.57-.38-1.81.588-1.81h3.461a1 1 0 00.951-.69l1.07-3.292z" />
45
+ </svg>
46
+ ))}
47
+ </div>
48
+ )}
49
+
50
+ {/* Title */}
51
+ <h3
52
+ style={{ color: "var(--color-secondary-800)" }}
53
+ className="font-secondary text-xl font-semibold mb-4 leading-7 -tracking-[0.06px]"
54
+ >
55
+ {title}
56
+ </h3>
57
+
58
+ {/* Content */}
59
+ <div className="flex-grow">
60
+ <p className="text-[var(--color-secondary-600)] leading-7 text-base tracking-[-0.04px] mb-6 line-clamp-4">
61
+ {content}
62
+ </p>
63
+ </div>
64
+
65
+ {/* Author info */}
66
+ {author && (
67
+ <div className="flex items-center gap-3 mt-auto">
68
+ {image && (
69
+ <Image
70
+ src={image}
71
+ alt={author}
72
+ width={40}
73
+ height={40}
74
+ quality={90}
75
+ className="rounded-full object-cover"
76
+ />
77
+ )}
78
+ <div className="flex justify-between w-full items-center">
79
+ <p
80
+ style={{ color: "var(--color-secondary-600)" }}
81
+ className="font-secondary font-semibold text-sm"
82
+ >
83
+ {author}
84
+ </p>
85
+ <span className="font-primary text-xs text-black">
86
+ {new Date(publishedAt).toLocaleDateString()}
87
+ </span>
88
+ </div>
89
+ </div>
90
+ )}
91
+ </div>
92
+ );
93
+ };
@@ -0,0 +1,318 @@
1
+ import React from "react"
2
+ import Link from "next/link"
3
+
4
+ export type EditorJsBlock = {
5
+ id: string
6
+ type: string
7
+ data: {
8
+ text?: string
9
+ level?: number
10
+ style?: "ordered" | "unordered"
11
+ items?: string[]
12
+ }
13
+ }
14
+
15
+ // Helper function to decode HTML entities
16
+ function decodeHtmlEntities(text: string): string {
17
+ const textarea = typeof document !== 'undefined'
18
+ ? document.createElement('textarea')
19
+ : null;
20
+
21
+ if (textarea) {
22
+ textarea.innerHTML = text;
23
+ return textarea.value;
24
+ }
25
+
26
+ // Fallback for server-side rendering
27
+ return text
28
+ .replace(/&lt;/g, '<')
29
+ .replace(/&gt;/g, '>')
30
+ .replace(/&amp;/g, '&')
31
+ .replace(/&quot;/g, '"')
32
+ .replace(/&#39;/g, "'")
33
+ .replace(/&nbsp;/g, ' ');
34
+ }
35
+
36
+ // Helper function to check if text contains HTML table elements
37
+ function isTableFragment(text: string): boolean {
38
+ const tablePatterns = [
39
+ /<table/i,
40
+ /<\/table>/i,
41
+ /<thead/i,
42
+ /<\/thead>/i,
43
+ /<tbody/i,
44
+ /<\/tbody>/i,
45
+ /<tr/i,
46
+ /<\/tr>/i,
47
+ /<td/i,
48
+ /<\/td>/i,
49
+ /<th/i,
50
+ /<\/th>/i,
51
+ /<colgroup/i,
52
+ /<\/colgroup>/i,
53
+ /<col/i,
54
+ ];
55
+ return tablePatterns.some(pattern => pattern.test(text));
56
+ }
57
+
58
+ // Helper function to merge table fragments
59
+ function mergeTableBlocks(blocks: EditorJsBlock[]): EditorJsBlock[] {
60
+ const merged: EditorJsBlock[] = [];
61
+ let tableBuffer: string[] = [];
62
+ let tableStartId: string | null = null;
63
+ let isInTable = false;
64
+
65
+ for (let i = 0; i < blocks.length; i++) {
66
+ const block = blocks[i];
67
+ const text = block.data?.text || "";
68
+ const decodedText = decodeHtmlEntities(text);
69
+
70
+ // Check if this starts a table
71
+ if (/<table/i.test(decodedText)) {
72
+ isInTable = true;
73
+ tableStartId = block.id;
74
+ }
75
+
76
+ if (block.type === "paragraph" && (isInTable || isTableFragment(decodedText))) {
77
+ // Start or continue accumulating table content
78
+ if (!tableStartId) {
79
+ tableStartId = block.id;
80
+ isInTable = true;
81
+ }
82
+
83
+ // Clean up individual fragments: remove <br> tags and preserve whitespace
84
+ const cleanedText = decodedText
85
+ .replace(/<br\s*\/?>/gi, '')
86
+ .replace(/^\s+|\s+$/g, ''); // Trim leading/trailing whitespace only
87
+
88
+ if (cleanedText) {
89
+ tableBuffer.push(cleanedText);
90
+ }
91
+
92
+ // Check if this closes the table
93
+ if (/<\/table>/i.test(decodedText)) {
94
+ isInTable = false;
95
+ // Create merged table block
96
+ const mergedHTML = tableBuffer.join('');
97
+ merged.push({
98
+ id: tableStartId || block.id,
99
+ type: "table",
100
+ data: {
101
+ text: mergedHTML
102
+ }
103
+ });
104
+ tableBuffer = [];
105
+ tableStartId = null;
106
+ }
107
+ } else {
108
+ // If we have accumulated table content, create a merged block
109
+ if (tableBuffer.length > 0 && tableStartId) {
110
+ // Join without extra newlines to preserve HTML structure
111
+ const mergedHTML = tableBuffer.join('');
112
+ merged.push({
113
+ id: tableStartId,
114
+ type: "table",
115
+ data: {
116
+ text: mergedHTML
117
+ }
118
+ });
119
+ tableBuffer = [];
120
+ tableStartId = null;
121
+ isInTable = false;
122
+ }
123
+ // Add the non-table block
124
+ merged.push(block);
125
+ }
126
+ }
127
+
128
+ // Handle any remaining table content
129
+ if (tableBuffer.length > 0 && tableStartId) {
130
+ const mergedHTML = tableBuffer.join('');
131
+ merged.push({
132
+ id: tableStartId,
133
+ type: "table",
134
+ data: {
135
+ text: mergedHTML
136
+ }
137
+ });
138
+ }
139
+
140
+ return merged;
141
+ }
142
+
143
+ export default function EditorRenderer({ content }: { content: string | null | undefined }) {
144
+ let blocks: EditorJsBlock[] = []
145
+ if (content) {
146
+ try {
147
+ const parsed = JSON.parse(content)
148
+ if (Array.isArray(parsed?.blocks)) {
149
+ blocks = parsed.blocks as EditorJsBlock[]
150
+ }
151
+ } catch (_) {}
152
+ }
153
+
154
+ if (!blocks.length) {
155
+ return (
156
+ <div className="w-full p-6">
157
+ <h2 className="text-xl font-semibold">Call for Availability</h2>
158
+ </div>
159
+ )
160
+ }
161
+
162
+ // Merge table fragments before rendering
163
+ const mergedBlocks = mergeTableBlocks(blocks);
164
+
165
+ const renderBlock = (block: EditorJsBlock) => {
166
+ const { type, data } = block
167
+ const html = decodeHtmlEntities(data?.text || "")
168
+
169
+ switch (type) {
170
+ case "table":
171
+ return (
172
+ <div
173
+ key={block.id}
174
+ className="table-wrapper my-6"
175
+ dangerouslySetInnerHTML={{ __html: data?.text || "" }}
176
+ />
177
+ );
178
+ case "header": {
179
+ const level = Math.min(Math.max(Number(data?.level) || 3, 1), 6)
180
+ return React.createElement(
181
+ `h${level}`,
182
+ {
183
+ key: block.id,
184
+ className: "text-2xl font-semibold leading-8 tracking-[-0.06px] my-6",
185
+ dangerouslySetInnerHTML: { __html: html },
186
+ }
187
+ )
188
+ }
189
+ case "list": {
190
+ const style = data?.style || "unordered"
191
+ const items = Array.isArray(data?.items) ? data.items : []
192
+ const ListTag = style === "ordered" ? "ol" : "ul"
193
+ const listClassName = style === "ordered"
194
+ ? "list-decimal list-inside my-4 space-y-2 text-lg leading-7 tracking-[-0.045px]"
195
+ : "list-disc list-inside my-4 space-y-2 text-lg leading-7 tracking-[-0.045px]"
196
+
197
+ return (
198
+ <ListTag key={block.id} className={listClassName}>
199
+ {items.map((item, idx) => (
200
+ <li key={`${block.id}-${idx}`} dangerouslySetInnerHTML={{ __html: decodeHtmlEntities(item) }} />
201
+ ))}
202
+ </ListTag>
203
+ )
204
+ }
205
+ case "paragraph":
206
+ default:
207
+ // Check if this paragraph contains table HTML that wasn't merged
208
+ if (isTableFragment(html)) {
209
+ return (
210
+ <div
211
+ key={block.id}
212
+ className="table-wrapper my-6"
213
+ dangerouslySetInnerHTML={{ __html: html }}
214
+ />
215
+ );
216
+ }
217
+ return (
218
+ <p
219
+ key={block.id}
220
+ className="text-lg leading-7 tracking-[-0.045px] my-4"
221
+ dangerouslySetInnerHTML={{ __html: html }}
222
+ />
223
+ )
224
+ }
225
+ }
226
+
227
+ return (
228
+ <>
229
+ <style dangerouslySetInnerHTML={{
230
+ __html: `
231
+ .editor-content a {
232
+ color: var(--color-primary-600);
233
+ text-decoration: underline;
234
+ transition: opacity 0.2s;
235
+ }
236
+ .editor-content a:hover {
237
+ opacity: 0.8;
238
+ }
239
+ .editor-content strong,
240
+ .editor-content b {
241
+ font-weight: 600;
242
+ }
243
+ .editor-content em,
244
+ .editor-content i {
245
+ font-style: italic;
246
+ }
247
+ .editor-content table {
248
+ width: 100% !important;
249
+ max-width: 100% !important;
250
+ border-collapse: collapse;
251
+ margin: 2rem 0;
252
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
253
+ display: table;
254
+ table-layout: auto !important;
255
+ }
256
+ .editor-content .table-wrapper {
257
+ width: 100%;
258
+ overflow-x: auto;
259
+ }
260
+ .editor-content table col {
261
+ width: auto !important;
262
+ }
263
+ .editor-content table colgroup {
264
+ display: table-column-group;
265
+ }
266
+ .editor-content table thead {
267
+ background-color: var(--color-primary-600);
268
+ color: white;
269
+ }
270
+ .editor-content table th,
271
+ .editor-content table td {
272
+ padding: 1rem 1.5rem;
273
+ text-align: left;
274
+ border: 1px solid var(--color-secondary-300);
275
+ line-height: 1.6;
276
+ }
277
+ .editor-content table th {
278
+ font-weight: 600;
279
+ font-size: 1rem;
280
+ }
281
+ .editor-content table tbody tr:nth-child(even) {
282
+ background-color: var(--color-secondary-50);
283
+ }
284
+ .editor-content table tbody tr:hover {
285
+ background-color: var(--color-secondary-100);
286
+ transition: background-color 0.2s ease;
287
+ }
288
+ .editor-content .table-header {
289
+ font-weight: 600;
290
+ font-size: 1.1rem;
291
+ padding: 1.25rem 1.5rem;
292
+ }
293
+ .editor-content .table-data {
294
+ font-size: 0.95rem;
295
+ padding: 0.875rem 1.25rem;
296
+ }
297
+ .ezo-table {
298
+ width: 100%;
299
+ border-collapse: collapse;
300
+ margin: 2rem 0;
301
+ }
302
+ @media (max-width: 768px) {
303
+ .editor-content table {
304
+ font-size: 0.875rem;
305
+ }
306
+ .editor-content table th,
307
+ .editor-content table td {
308
+ padding: 0.75rem 1rem;
309
+ }
310
+ }
311
+ `
312
+ }} />
313
+ <div className="editor-content overflow-x-auto">
314
+ {mergedBlocks.map(renderBlock)}
315
+ </div>
316
+ </>
317
+ )
318
+ }