@ikas/component-cli 0.93.0 → 0.94.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 (374) hide show
  1. package/dist/commands/create.d.ts.map +1 -1
  2. package/dist/commands/create.js +108 -42
  3. package/dist/commands/create.js.map +1 -1
  4. package/dist/index.d.ts.map +1 -1
  5. package/dist/index.js +2 -0
  6. package/dist/index.js.map +1 -1
  7. package/dist/utils/component-helpers.js +1 -1
  8. package/dist/utils/component-helpers.js.map +1 -1
  9. package/dist/utils/template.d.ts +12 -0
  10. package/dist/utils/template.d.ts.map +1 -1
  11. package/dist/utils/template.js +44 -0
  12. package/dist/utils/template.js.map +1 -1
  13. package/package.json +3 -2
  14. package/templates/create/claude-md +1 -1
  15. package/templates/create/cursorrules +1 -1
  16. package/templates/create/src/components/ExampleComponent/types.ts +1 -1
  17. package/templates/create/src/components/ExampleSection/types.ts +1 -1
  18. package/templates/create-full/README.md +78 -0
  19. package/templates/create-full/claude-md +721 -0
  20. package/templates/create-full/cursorrules +103 -0
  21. package/templates/create-full/gitignore +4 -0
  22. package/templates/create-full/ikas.config.json +5007 -0
  23. package/templates/create-full/mcp.json +10 -0
  24. package/templates/create-full/package.json +17 -0
  25. package/templates/create-full/src/components/AccountAddresses/components/AddressCard/index.tsx +55 -0
  26. package/templates/create-full/src/components/AccountAddresses/components/AddressCard/styles.css +46 -0
  27. package/templates/create-full/src/components/AccountAddresses/components/AddressModal/index.tsx +301 -0
  28. package/templates/create-full/src/components/AccountAddresses/components/AddressModal/styles.css +22 -0
  29. package/templates/create-full/src/components/AccountAddresses/index.tsx +127 -0
  30. package/templates/create-full/src/components/AccountAddresses/styles.css +41 -0
  31. package/templates/create-full/src/components/AccountAddresses/types.ts +15 -0
  32. package/templates/create-full/src/components/AccountFavorites/index.tsx +82 -0
  33. package/templates/create-full/src/components/AccountFavorites/styles.css +52 -0
  34. package/templates/create-full/src/components/AccountFavorites/types.ts +7 -0
  35. package/templates/create-full/src/components/AccountInfo/components/AccountSidebar/index.tsx +171 -0
  36. package/templates/create-full/src/components/AccountInfo/components/AccountSidebar/styles.css +144 -0
  37. package/templates/create-full/src/components/AccountInfo/index.tsx +91 -0
  38. package/templates/create-full/src/components/AccountInfo/styles.css +35 -0
  39. package/templates/create-full/src/components/AccountInfo/types.ts +9 -0
  40. package/templates/create-full/src/components/AccountInfoContent/index.tsx +134 -0
  41. package/templates/create-full/src/components/AccountInfoContent/styles.css +57 -0
  42. package/templates/create-full/src/components/AccountInfoContent/types.ts +8 -0
  43. package/templates/create-full/src/components/AccountOrderDetail/components/OrderHeader/index.tsx +78 -0
  44. package/templates/create-full/src/components/AccountOrderDetail/components/OrderHeader/styles.css +46 -0
  45. package/templates/create-full/src/components/AccountOrderDetail/components/OrderItemRow/index.tsx +20 -0
  46. package/templates/create-full/src/components/AccountOrderDetail/components/OrderItemRow/styles.css +16 -0
  47. package/templates/create-full/src/components/AccountOrderDetail/components/OrderLineItemDisplay/index.tsx +112 -0
  48. package/templates/create-full/src/components/AccountOrderDetail/components/OrderLineItemDisplay/styles.css +86 -0
  49. package/templates/create-full/src/components/AccountOrderDetail/components/OrderSidebar/index.tsx +195 -0
  50. package/templates/create-full/src/components/AccountOrderDetail/components/OrderSidebar/styles.css +93 -0
  51. package/templates/create-full/src/components/AccountOrderDetail/components/PackageGroup/index.tsx +156 -0
  52. package/templates/create-full/src/components/AccountOrderDetail/components/PackageGroup/styles.css +100 -0
  53. package/templates/create-full/src/components/AccountOrderDetail/components/ReturnItemRow/index.tsx +56 -0
  54. package/templates/create-full/src/components/AccountOrderDetail/components/ReturnItemRow/styles.css +57 -0
  55. package/templates/create-full/src/components/AccountOrderDetail/components/ReturnView/index.tsx +159 -0
  56. package/templates/create-full/src/components/AccountOrderDetail/components/ReturnView/styles.css +29 -0
  57. package/templates/create-full/src/components/AccountOrderDetail/index.tsx +244 -0
  58. package/templates/create-full/src/components/AccountOrderDetail/styles.css +125 -0
  59. package/templates/create-full/src/components/AccountOrderDetail/types.ts +32 -0
  60. package/templates/create-full/src/components/AccountOrders/components/OrderCard/index.tsx +122 -0
  61. package/templates/create-full/src/components/AccountOrders/components/OrderCard/styles.css +114 -0
  62. package/templates/create-full/src/components/AccountOrders/index.tsx +105 -0
  63. package/templates/create-full/src/components/AccountOrders/styles.css +36 -0
  64. package/templates/create-full/src/components/AccountOrders/types.ts +11 -0
  65. package/templates/create-full/src/components/Announcement/index.tsx +11 -0
  66. package/templates/create-full/src/components/Announcement/styles.css +4 -0
  67. package/templates/create-full/src/components/Announcement/types.ts +4 -0
  68. package/templates/create-full/src/components/Announcements/index.tsx +91 -0
  69. package/templates/create-full/src/components/Announcements/styles.css +45 -0
  70. package/templates/create-full/src/components/Announcements/types.ts +8 -0
  71. package/templates/create-full/src/components/BlogHome/components/BlogCard/index.tsx +89 -0
  72. package/templates/create-full/src/components/BlogHome/components/BlogCard/styles.css +121 -0
  73. package/templates/create-full/src/components/BlogHome/index.tsx +124 -0
  74. package/templates/create-full/src/components/BlogHome/styles.css +118 -0
  75. package/templates/create-full/src/components/BlogHome/types.ts +15 -0
  76. package/templates/create-full/src/components/BlogPost/index.tsx +128 -0
  77. package/templates/create-full/src/components/BlogPost/styles.css +120 -0
  78. package/templates/create-full/src/components/BlogPost/types.ts +12 -0
  79. package/templates/create-full/src/components/CardProductName/index.tsx +25 -0
  80. package/templates/create-full/src/components/CardProductName/styles.css +22 -0
  81. package/templates/create-full/src/components/CardProductName/types.ts +7 -0
  82. package/templates/create-full/src/components/CardProductPrice/index.tsx +30 -0
  83. package/templates/create-full/src/components/CardProductPrice/styles.css +13 -0
  84. package/templates/create-full/src/components/CardProductPrice/types.ts +6 -0
  85. package/templates/create-full/src/components/CardProductVariants/index.tsx +10 -0
  86. package/templates/create-full/src/components/CardProductVariants/styles.css +1 -0
  87. package/templates/create-full/src/components/CardProductVariants/types.ts +6 -0
  88. package/templates/create-full/src/components/CartPage/components/CouponCode/index.tsx +108 -0
  89. package/templates/create-full/src/components/CartPage/components/CouponCode/styles.css +68 -0
  90. package/templates/create-full/src/components/CartPage/components/EmptyState/index.tsx +31 -0
  91. package/templates/create-full/src/components/CartPage/components/EmptyState/styles.css +18 -0
  92. package/templates/create-full/src/components/CartPage/components/OrderSummary/index.tsx +106 -0
  93. package/templates/create-full/src/components/CartPage/components/OrderSummary/styles.css +70 -0
  94. package/templates/create-full/src/components/CartPage/index.tsx +107 -0
  95. package/templates/create-full/src/components/CartPage/styles.css +54 -0
  96. package/templates/create-full/src/components/CartPage/types.ts +16 -0
  97. package/templates/create-full/src/components/CategoryImageItem/components/Card/index.tsx +64 -0
  98. package/templates/create-full/src/components/CategoryImageItem/components/Card/styles.css +56 -0
  99. package/templates/create-full/src/components/CategoryImageItem/index.tsx +64 -0
  100. package/templates/create-full/src/components/CategoryImageItem/styles.css +10 -0
  101. package/templates/create-full/src/components/CategoryImageItem/types.ts +16 -0
  102. package/templates/create-full/src/components/CategoryImages/index.tsx +62 -0
  103. package/templates/create-full/src/components/CategoryImages/styles.css +38 -0
  104. package/templates/create-full/src/components/CategoryImages/types.ts +11 -0
  105. package/templates/create-full/src/components/CategoryList/components/CategoryListControls/index.tsx +129 -0
  106. package/templates/create-full/src/components/CategoryList/components/CategoryListControls/styles.css +99 -0
  107. package/templates/create-full/src/components/CategoryList/components/FilterBoxValues/index.tsx +42 -0
  108. package/templates/create-full/src/components/CategoryList/components/FilterBoxValues/styles.css +27 -0
  109. package/templates/create-full/src/components/CategoryList/components/FilterCategoryList/index.tsx +43 -0
  110. package/templates/create-full/src/components/CategoryList/components/FilterCategoryList/styles.css +20 -0
  111. package/templates/create-full/src/components/CategoryList/components/FilterGroupValues/index.tsx +114 -0
  112. package/templates/create-full/src/components/CategoryList/components/FilterGroupValues/styles.css +1 -0
  113. package/templates/create-full/src/components/CategoryList/components/FilterListValues/index.tsx +54 -0
  114. package/templates/create-full/src/components/CategoryList/components/FilterListValues/styles.css +22 -0
  115. package/templates/create-full/src/components/CategoryList/components/FilterRangeListValues/index.tsx +50 -0
  116. package/templates/create-full/src/components/CategoryList/components/FilterRangeListValues/styles.css +25 -0
  117. package/templates/create-full/src/components/CategoryList/components/FilterRangeValues/index.tsx +189 -0
  118. package/templates/create-full/src/components/CategoryList/components/FilterRangeValues/styles.css +89 -0
  119. package/templates/create-full/src/components/CategoryList/components/FilterSidebar/index.tsx +92 -0
  120. package/templates/create-full/src/components/CategoryList/components/FilterSidebar/styles.css +27 -0
  121. package/templates/create-full/src/components/CategoryList/components/FilterSwatchValues/index.tsx +63 -0
  122. package/templates/create-full/src/components/CategoryList/components/FilterSwatchValues/styles.css +48 -0
  123. package/templates/create-full/src/components/CategoryList/components/MobileFilterModal/index.tsx +146 -0
  124. package/templates/create-full/src/components/CategoryList/components/MobileFilterModal/styles.css +133 -0
  125. package/templates/create-full/src/components/CategoryList/index.tsx +333 -0
  126. package/templates/create-full/src/components/CategoryList/styles.css +110 -0
  127. package/templates/create-full/src/components/CategoryList/types.ts +30 -0
  128. package/templates/create-full/src/components/CollapsibleContent/index.tsx +23 -0
  129. package/templates/create-full/src/components/CollapsibleContent/styles.css +11 -0
  130. package/templates/create-full/src/components/CollapsibleContent/types.ts +6 -0
  131. package/templates/create-full/src/components/CookieBar/index.tsx +78 -0
  132. package/templates/create-full/src/components/CookieBar/styles.css +111 -0
  133. package/templates/create-full/src/components/CookieBar/types.ts +10 -0
  134. package/templates/create-full/src/components/CustomerEmailVerification/index.tsx +168 -0
  135. package/templates/create-full/src/components/CustomerEmailVerification/styles.css +118 -0
  136. package/templates/create-full/src/components/CustomerEmailVerification/types.ts +17 -0
  137. package/templates/create-full/src/components/FeatureItem/index.tsx +27 -0
  138. package/templates/create-full/src/components/FeatureItem/styles.css +19 -0
  139. package/templates/create-full/src/components/FeatureItem/types.ts +7 -0
  140. package/templates/create-full/src/components/Features/index.tsx +25 -0
  141. package/templates/create-full/src/components/Features/styles.css +39 -0
  142. package/templates/create-full/src/components/Features/types.ts +5 -0
  143. package/templates/create-full/src/components/Footer/index.tsx +154 -0
  144. package/templates/create-full/src/components/Footer/styles.css +175 -0
  145. package/templates/create-full/src/components/Footer/types.ts +15 -0
  146. package/templates/create-full/src/components/ForgotPassword/components/ForgotPasswordForm/index.tsx +129 -0
  147. package/templates/create-full/src/components/ForgotPassword/components/ForgotPasswordForm/styles.css +0 -0
  148. package/templates/create-full/src/components/ForgotPassword/index.tsx +30 -0
  149. package/templates/create-full/src/components/ForgotPassword/styles.css +85 -0
  150. package/templates/create-full/src/components/ForgotPassword/types.ts +13 -0
  151. package/templates/create-full/src/components/Header/index.tsx +53 -0
  152. package/templates/create-full/src/components/Header/styles.css +6 -0
  153. package/templates/create-full/src/components/Header/types.ts +6 -0
  154. package/templates/create-full/src/components/HeroSlider/index.tsx +110 -0
  155. package/templates/create-full/src/components/HeroSlider/styles.css +129 -0
  156. package/templates/create-full/src/components/HeroSlider/types.ts +9 -0
  157. package/templates/create-full/src/components/HeroSliderItem/index.tsx +231 -0
  158. package/templates/create-full/src/components/HeroSliderItem/styles.css +152 -0
  159. package/templates/create-full/src/components/HeroSliderItem/types.ts +34 -0
  160. package/templates/create-full/src/components/Login/components/LoginForm/index.tsx +181 -0
  161. package/templates/create-full/src/components/Login/components/LoginForm/styles.css +0 -0
  162. package/templates/create-full/src/components/Login/index.tsx +37 -0
  163. package/templates/create-full/src/components/Login/styles.css +129 -0
  164. package/templates/create-full/src/components/Login/types.ts +18 -0
  165. package/templates/create-full/src/components/Navbar/components/CartSidebar/index.tsx +203 -0
  166. package/templates/create-full/src/components/Navbar/components/CartSidebar/styles.css +175 -0
  167. package/templates/create-full/src/components/Navbar/components/MobileMenu/index.tsx +198 -0
  168. package/templates/create-full/src/components/Navbar/components/MobileMenu/styles.css +122 -0
  169. package/templates/create-full/src/components/Navbar/components/NavItem/index.tsx +65 -0
  170. package/templates/create-full/src/components/Navbar/components/SearchModal/index.tsx +267 -0
  171. package/templates/create-full/src/components/Navbar/components/SearchModal/styles.css +182 -0
  172. package/templates/create-full/src/components/Navbar/index.tsx +250 -0
  173. package/templates/create-full/src/components/Navbar/styles.css +243 -0
  174. package/templates/create-full/src/components/Navbar/types.ts +37 -0
  175. package/templates/create-full/src/components/NotFound/index.tsx +39 -0
  176. package/templates/create-full/src/components/NotFound/styles.css +46 -0
  177. package/templates/create-full/src/components/NotFound/types.ts +8 -0
  178. package/templates/create-full/src/components/ProductDetail/components/ProductGallery/index.tsx +316 -0
  179. package/templates/create-full/src/components/ProductDetail/components/ProductGallery/styles.css +213 -0
  180. package/templates/create-full/src/components/ProductDetail/index.tsx +92 -0
  181. package/templates/create-full/src/components/ProductDetail/styles.css +58 -0
  182. package/templates/create-full/src/components/ProductDetail/types.ts +12 -0
  183. package/templates/create-full/src/components/ProductDetailAddToCart/components/PayWithIkas/index.tsx +34 -0
  184. package/templates/create-full/src/components/ProductDetailAddToCart/components/PayWithIkas/styles.css +4 -0
  185. package/templates/create-full/src/components/ProductDetailAddToCart/index.tsx +146 -0
  186. package/templates/create-full/src/components/ProductDetailAddToCart/styles.css +27 -0
  187. package/templates/create-full/src/components/ProductDetailAddToCart/types.ts +18 -0
  188. package/templates/create-full/src/components/ProductDetailBundleFurniture/components/BundleFurnitureRow/index.tsx +164 -0
  189. package/templates/create-full/src/components/ProductDetailBundleFurniture/components/BundleFurnitureSection/index.tsx +134 -0
  190. package/templates/create-full/src/components/ProductDetailBundleFurniture/components/BundleFurnitureSection/styles.css +188 -0
  191. package/templates/create-full/src/components/ProductDetailBundleFurniture/index.tsx +61 -0
  192. package/templates/create-full/src/components/ProductDetailBundleFurniture/styles.css +12 -0
  193. package/templates/create-full/src/components/ProductDetailBundleFurniture/types.ts +21 -0
  194. package/templates/create-full/src/components/ProductDetailBundleProduct/components/BundleProductItem/index.tsx +169 -0
  195. package/templates/create-full/src/components/ProductDetailBundleProduct/components/BundleProductItem/styles.css +141 -0
  196. package/templates/create-full/src/components/ProductDetailBundleProduct/components/BundleSkeletonLoading/index.tsx +35 -0
  197. package/templates/create-full/src/components/ProductDetailBundleProduct/components/BundleSkeletonLoading/styles.css +85 -0
  198. package/templates/create-full/src/components/ProductDetailBundleProduct/components/FurnitureRow/index.tsx +51 -0
  199. package/templates/create-full/src/components/ProductDetailBundleProduct/components/FurnitureRow/styles.css +30 -0
  200. package/templates/create-full/src/components/ProductDetailBundleProduct/components/FurnitureView/index.tsx +54 -0
  201. package/templates/create-full/src/components/ProductDetailBundleProduct/components/FurnitureView/styles.css +22 -0
  202. package/templates/create-full/src/components/ProductDetailBundleProduct/index.tsx +101 -0
  203. package/templates/create-full/src/components/ProductDetailBundleProduct/styles.css +20 -0
  204. package/templates/create-full/src/components/ProductDetailBundleProduct/types.ts +18 -0
  205. package/templates/create-full/src/components/ProductDetailDescription/index.tsx +56 -0
  206. package/templates/create-full/src/components/ProductDetailDescription/styles.css +21 -0
  207. package/templates/create-full/src/components/ProductDetailDescription/types.ts +13 -0
  208. package/templates/create-full/src/components/ProductDetailFeatureItem/index.tsx +28 -0
  209. package/templates/create-full/src/components/ProductDetailFeatureItem/styles.css +22 -0
  210. package/templates/create-full/src/components/ProductDetailFeatureItem/types.ts +7 -0
  211. package/templates/create-full/src/components/ProductDetailFeatures/index.tsx +40 -0
  212. package/templates/create-full/src/components/ProductDetailFeatures/styles.css +17 -0
  213. package/templates/create-full/src/components/ProductDetailFeatures/types.ts +10 -0
  214. package/templates/create-full/src/components/ProductDetailNameFavorite/index.tsx +66 -0
  215. package/templates/create-full/src/components/ProductDetailNameFavorite/styles.css +45 -0
  216. package/templates/create-full/src/components/ProductDetailNameFavorite/types.ts +11 -0
  217. package/templates/create-full/src/components/ProductDetailOffer/components/OfferCard/index.tsx +209 -0
  218. package/templates/create-full/src/components/ProductDetailOffer/components/OfferCard/styles.css +146 -0
  219. package/templates/create-full/src/components/ProductDetailOffer/components/OfferSummary/index.tsx +175 -0
  220. package/templates/create-full/src/components/ProductDetailOffer/index.tsx +199 -0
  221. package/templates/create-full/src/components/ProductDetailOffer/styles.css +211 -0
  222. package/templates/create-full/src/components/ProductDetailOffer/types.ts +24 -0
  223. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionCheckbox/index.tsx +52 -0
  224. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionCheckbox/styles.css +19 -0
  225. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceBox/index.tsx +60 -0
  226. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceBox/styles.css +38 -0
  227. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceSelect/index.tsx +102 -0
  228. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceSelect/styles.css +34 -0
  229. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceSwatch/index.tsx +121 -0
  230. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/components/ChoiceSwatch/styles.css +87 -0
  231. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionChoice/index.tsx +57 -0
  232. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionColorPicker/index.tsx +54 -0
  233. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionColorPicker/styles.css +0 -0
  234. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionDatePicker/index.tsx +124 -0
  235. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionDatePicker/styles.css +1 -0
  236. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionFile/index.tsx +217 -0
  237. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionFile/styles.css +87 -0
  238. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionRenderer/index.tsx +133 -0
  239. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionText/index.tsx +60 -0
  240. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionText/styles.css +1 -0
  241. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionTextarea/index.tsx +74 -0
  242. package/templates/create-full/src/components/ProductDetailOptionSet/components/OptionTextarea/styles.css +10 -0
  243. package/templates/create-full/src/components/ProductDetailOptionSet/index.tsx +99 -0
  244. package/templates/create-full/src/components/ProductDetailOptionSet/styles.css +30 -0
  245. package/templates/create-full/src/components/ProductDetailOptionSet/types.ts +21 -0
  246. package/templates/create-full/src/components/ProductDetailPrices/index.tsx +62 -0
  247. package/templates/create-full/src/components/ProductDetailPrices/styles.css +32 -0
  248. package/templates/create-full/src/components/ProductDetailPrices/types.ts +10 -0
  249. package/templates/create-full/src/components/ProductDetailProductGroup/index.tsx +74 -0
  250. package/templates/create-full/src/components/ProductDetailProductGroup/styles.css +33 -0
  251. package/templates/create-full/src/components/ProductDetailProductGroup/types.ts +10 -0
  252. package/templates/create-full/src/components/ProductDetailReviews/index.tsx +205 -0
  253. package/templates/create-full/src/components/ProductDetailReviews/styles.css +43 -0
  254. package/templates/create-full/src/components/ProductDetailReviews/types.ts +19 -0
  255. package/templates/create-full/src/components/ProductDetailSku/index.tsx +38 -0
  256. package/templates/create-full/src/components/ProductDetailSku/styles.css +16 -0
  257. package/templates/create-full/src/components/ProductDetailSku/types.ts +11 -0
  258. package/templates/create-full/src/components/ProductDetailVariant/index.tsx +38 -0
  259. package/templates/create-full/src/components/ProductDetailVariant/styles.css +14 -0
  260. package/templates/create-full/src/components/ProductDetailVariant/types.ts +12 -0
  261. package/templates/create-full/src/components/ProductSlider/index.tsx +151 -0
  262. package/templates/create-full/src/components/ProductSlider/styles.css +105 -0
  263. package/templates/create-full/src/components/ProductSlider/types.ts +17 -0
  264. package/templates/create-full/src/components/RecoverPassword/components/RecoverPasswordForm/index.tsx +133 -0
  265. package/templates/create-full/src/components/RecoverPassword/components/RecoverPasswordForm/styles.css +0 -0
  266. package/templates/create-full/src/components/RecoverPassword/index.tsx +30 -0
  267. package/templates/create-full/src/components/RecoverPassword/styles.css +93 -0
  268. package/templates/create-full/src/components/RecoverPassword/types.ts +13 -0
  269. package/templates/create-full/src/components/Register/components/RegisterForm/index.tsx +326 -0
  270. package/templates/create-full/src/components/Register/components/RegisterForm/styles.css +0 -0
  271. package/templates/create-full/src/components/Register/index.tsx +30 -0
  272. package/templates/create-full/src/components/Register/styles.css +152 -0
  273. package/templates/create-full/src/components/Register/types.ts +27 -0
  274. package/templates/create-full/src/components/RichText/index.tsx +25 -0
  275. package/templates/create-full/src/components/RichText/styles.css +51 -0
  276. package/templates/create-full/src/components/RichText/types.ts +5 -0
  277. package/templates/create-full/src/components/SocialMediaIcon/index.tsx +26 -0
  278. package/templates/create-full/src/components/SocialMediaIcon/styles.css +17 -0
  279. package/templates/create-full/src/components/SocialMediaIcon/types.ts +7 -0
  280. package/templates/create-full/src/components/index.ts +50 -0
  281. package/templates/create-full/src/global-types.ts +13 -0
  282. package/templates/create-full/src/global.css +582 -0
  283. package/templates/create-full/src/hooks/useBundleProducts.ts +75 -0
  284. package/templates/create-full/src/hooks/useColumnPreference.ts +26 -0
  285. package/templates/create-full/src/hooks/useInfiniteScroll.ts +49 -0
  286. package/templates/create-full/src/hooks/usePageTracking.ts +56 -0
  287. package/templates/create-full/src/hooks/usePayWithIkas.ts +114 -0
  288. package/templates/create-full/src/hooks/useRedirectIfLoggedIn.ts +35 -0
  289. package/templates/create-full/src/hooks/useScrollLock.ts +20 -0
  290. package/templates/create-full/src/hooks/useToast.ts +27 -0
  291. package/templates/create-full/src/ikas-component-utils.d.ts +3 -0
  292. package/templates/create-full/src/sub-components/Badge/index.tsx +208 -0
  293. package/templates/create-full/src/sub-components/Badge/styles.css +129 -0
  294. package/templates/create-full/src/sub-components/Breadcrumb/index.tsx +57 -0
  295. package/templates/create-full/src/sub-components/Breadcrumb/styles.css +49 -0
  296. package/templates/create-full/src/sub-components/BundleMedia/index.tsx +72 -0
  297. package/templates/create-full/src/sub-components/BundleQuantityBox/index.tsx +73 -0
  298. package/templates/create-full/src/sub-components/BundleQuantityBox/styles.css +43 -0
  299. package/templates/create-full/src/sub-components/Button/index.tsx +52 -0
  300. package/templates/create-full/src/sub-components/Button/styles.css +114 -0
  301. package/templates/create-full/src/sub-components/CartItem/components/BundleProductItem/index.tsx +59 -0
  302. package/templates/create-full/src/sub-components/CartItem/components/BundleProductItem/styles.css +24 -0
  303. package/templates/create-full/src/sub-components/CartItem/components/BundleProducts/index.tsx +55 -0
  304. package/templates/create-full/src/sub-components/CartItem/components/BundleProducts/styles.css +30 -0
  305. package/templates/create-full/src/sub-components/CartItem/components/ItemOptions/index.tsx +31 -0
  306. package/templates/create-full/src/sub-components/CartItem/components/ItemOptions/styles.css +6 -0
  307. package/templates/create-full/src/sub-components/CartItem/components/OptionValueDisplay/index.tsx +79 -0
  308. package/templates/create-full/src/sub-components/CartItem/components/OptionValueDisplay/styles.css +28 -0
  309. package/templates/create-full/src/sub-components/CartItem/index.tsx +216 -0
  310. package/templates/create-full/src/sub-components/CartItem/styles.css +170 -0
  311. package/templates/create-full/src/sub-components/Checkbox/index.tsx +42 -0
  312. package/templates/create-full/src/sub-components/Checkbox/styles.css +65 -0
  313. package/templates/create-full/src/sub-components/CollapsibleGroup/index.tsx +52 -0
  314. package/templates/create-full/src/sub-components/CollapsibleGroup/styles.css +51 -0
  315. package/templates/create-full/src/sub-components/ColorInput/index.tsx +33 -0
  316. package/templates/create-full/src/sub-components/ColorInput/styles.css +53 -0
  317. package/templates/create-full/src/sub-components/ConfirmModal/index.tsx +60 -0
  318. package/templates/create-full/src/sub-components/ConfirmModal/styles.css +20 -0
  319. package/templates/create-full/src/sub-components/FormItem/index.tsx +66 -0
  320. package/templates/create-full/src/sub-components/FormItem/styles.css +38 -0
  321. package/templates/create-full/src/sub-components/ImagePreviewModal/index.tsx +55 -0
  322. package/templates/create-full/src/sub-components/ImagePreviewModal/styles.css +50 -0
  323. package/templates/create-full/src/sub-components/Input/index.tsx +69 -0
  324. package/templates/create-full/src/sub-components/Input/styles.css +162 -0
  325. package/templates/create-full/src/sub-components/Modal/index.tsx +118 -0
  326. package/templates/create-full/src/sub-components/Modal/styles.css +70 -0
  327. package/templates/create-full/src/sub-components/PageLoader/index.tsx +14 -0
  328. package/templates/create-full/src/sub-components/PageLoader/styles.css +12 -0
  329. package/templates/create-full/src/sub-components/Pagination/index.tsx +107 -0
  330. package/templates/create-full/src/sub-components/Pagination/styles.css +88 -0
  331. package/templates/create-full/src/sub-components/ProductCard/index.tsx +276 -0
  332. package/templates/create-full/src/sub-components/ProductCard/styles.css +99 -0
  333. package/templates/create-full/src/sub-components/QuantitySelector/index.tsx +41 -0
  334. package/templates/create-full/src/sub-components/QuantitySelector/styles.css +51 -0
  335. package/templates/create-full/src/sub-components/ReviewCard/index.tsx +103 -0
  336. package/templates/create-full/src/sub-components/ReviewCard/styles.css +95 -0
  337. package/templates/create-full/src/sub-components/ReviewForm/index.tsx +115 -0
  338. package/templates/create-full/src/sub-components/ReviewForm/styles.css +11 -0
  339. package/templates/create-full/src/sub-components/ReviewSummary/index.tsx +65 -0
  340. package/templates/create-full/src/sub-components/ReviewSummary/styles.css +86 -0
  341. package/templates/create-full/src/sub-components/Select/index.tsx +86 -0
  342. package/templates/create-full/src/sub-components/Select/styles.css +110 -0
  343. package/templates/create-full/src/sub-components/SkeletonField/index.tsx +12 -0
  344. package/templates/create-full/src/sub-components/SkeletonField/styles.css +29 -0
  345. package/templates/create-full/src/sub-components/SliderArrow/index.tsx +26 -0
  346. package/templates/create-full/src/sub-components/SliderArrow/styles.css +24 -0
  347. package/templates/create-full/src/sub-components/SocialLoginButton/index.tsx +24 -0
  348. package/templates/create-full/src/sub-components/SocialLoginButton/styles.css +19 -0
  349. package/templates/create-full/src/sub-components/SpinnerIcon/index.tsx +10 -0
  350. package/templates/create-full/src/sub-components/SpinnerIcon/styles.css +8 -0
  351. package/templates/create-full/src/sub-components/StarRating/index.tsx +76 -0
  352. package/templates/create-full/src/sub-components/StarRating/styles.css +40 -0
  353. package/templates/create-full/src/sub-components/Tag/index.tsx +21 -0
  354. package/templates/create-full/src/sub-components/Tag/styles.css +30 -0
  355. package/templates/create-full/src/sub-components/Textarea/index.tsx +45 -0
  356. package/templates/create-full/src/sub-components/Textarea/styles.css +82 -0
  357. package/templates/create-full/src/sub-components/Toast/index.tsx +257 -0
  358. package/templates/create-full/src/sub-components/Toast/styles.css +3 -0
  359. package/templates/create-full/src/sub-components/Toggle/index.tsx +46 -0
  360. package/templates/create-full/src/sub-components/Toggle/styles.css +86 -0
  361. package/templates/create-full/src/sub-components/VariantBadge/index.tsx +153 -0
  362. package/templates/create-full/src/sub-components/VariantBadge/styles.css +47 -0
  363. package/templates/create-full/src/sub-components/icons/index.tsx +981 -0
  364. package/templates/create-full/src/utils/bundle.ts +70 -0
  365. package/templates/create-full/src/utils/cx.ts +4 -0
  366. package/templates/create-full/src/utils/fullName.ts +6 -0
  367. package/templates/create-full/src/utils/media.ts +36 -0
  368. package/templates/create-full/src/utils/optionPrice.ts +19 -0
  369. package/templates/create-full/src/utils/optionSet.ts +17 -0
  370. package/templates/create-full/src/utils/orderStatus.ts +28 -0
  371. package/templates/create-full/src/utils/pagination.ts +29 -0
  372. package/templates/create-full/src/utils/toast.ts +5 -0
  373. package/templates/create-full/tsconfig.json +30 -0
  374. package/templates/create-full/vite.config.ts +15 -0
@@ -0,0 +1,103 @@
1
+ # ikas Code Components
2
+
3
+ You are building **Preact + TypeScript components for an e-commerce storefront**.
4
+ **ALWAYS query MCP tools before writing code that uses storefront APIs.**
5
+
6
+ ## CRITICAL: Auto-Generated Files
7
+
8
+ **NEVER manually create or edit `types.ts`** — it is auto-generated by CLI commands.
9
+ Use `npx ikas-component config add-component --props '[...]'` or `npx ikas-component config add-prop` to manage props.
10
+ These commands update BOTH `ikas.config.json` AND `types.ts` automatically.
11
+
12
+ ## MCP Tools (12 tools)
13
+
14
+ ### Starting a New Section
15
+ - get_section_template(sectionType) — **Start here** — production-ready starter template for common sections (header, footer, product-detail, product-list, cart, login, hero-banner, blog-post, faq, etc.)
16
+ - get_framework_guide(topic) — Framework docs ("ai-workflow", "common-pitfalls", "prop-types", "css-scoping", "form-handling", "imports")
17
+ - get_code_example(task) — Code examples ("add to cart", "variant selection", "image-handling")
18
+
19
+ ### Looking Up APIs
20
+ - search_docs(query) — Search all storefront API docs and framework guides
21
+ - get_function_doc(name) — Full docs for a function (e.g. "addItemToCart", "Router.navigate")
22
+ - list_functions(category?) — List functions by category (ProductDetail, Cart, ProductList, Navigation, Customer, Order, Image, Blog, Brand, Pricing, Form, Validation, Pagination, Filtering)
23
+ - get_prop_types() — All available ikas.config.json prop types
24
+
25
+ ### Exploring Types
26
+ - get_model_guide(model) — **One-stop-shop** — type def + utility functions + examples for a model (e.g. "IkasProduct", "IkasOrder")
27
+ - get_type_definition(name) — Full definition of a type or enum
28
+ - get_functions_for_type(typeName) — All utility functions for a type
29
+ - search_types(query) — Search types/enums by keyword ("price", "address", "status")
30
+ - list_types(domain?, kind?) — List all types, filter by domain or kind ("type"/"enum")
31
+
32
+ ## CLI Commands (never edit ikas.config.json or types.ts manually)
33
+ - npx ikas-component config add-component --name "Name" --type section --props '[...]' — **Primary** — create with all props in one command
34
+ - npx ikas-component config add-component --name "Name" --type section — Create component with no props
35
+ - npx ikas-component config add-prop --component "Name" --name title --displayName "Title" --type TEXT --required [--group content] — Add a prop incrementally
36
+ - npx ikas-component config update-prop --component "Name" --prop title --type RICH_TEXT [--group colors] — Update a prop or group
37
+ - npx ikas-component config remove-prop --component "Name" --prop title — Remove a prop
38
+ - npx ikas-component config remove-component --name "Name" — Remove a component
39
+ - npx ikas-component config add-prop-group --component "Name" --id colors --name "Colors" [--parent style] — Create a prop group
40
+ - npx ikas-component config update-prop-group --component "Name" --id colors [--name "..."] — Update a prop group
41
+ - npx ikas-component config remove-prop-group --component "Name" --id colors — Remove a prop group
42
+ - npx ikas-component config list — List all components and their props
43
+ - npx ikas-component check --json — Type-check all components
44
+ - npx ikas-component build — Compile server.js + client.js + styles.css per component
45
+ - npx ikas-component dev — Start dev server (Vite 5200 + WebSocket 5201)
46
+
47
+ ## Workflow: Building a New Section
48
+ 1. get_section_template("product-detail") → get starter files + CLI command with --props
49
+ 2. Run the CLI command (creates component + props + types.ts in one step)
50
+ 3. Write index.tsx and styles.css using the template (do NOT edit types.ts — it's already generated)
51
+ 4. Look up APIs: get_model_guide("IkasProduct"), get_function_doc("addItemToCart")
52
+ 5. npx ikas-component check --json → fix type errors
53
+ 6. npx ikas-component build → verify clean build
54
+
55
+ ## Sub-Component Structure
56
+ **ALWAYS create sub-components in `src/sub-components/` with their own folder containing `index.tsx` and `styles.css`.**
57
+ - `src/components/` = registered in ikas.config.json. `src/sub-components/` = internal helpers (NOT in ikas.config.json)
58
+ - Sub-components do NOT have `types.ts` — define `Props` inline in `index.tsx`
59
+ - CSS: `@import "../../sub-components/ProductCard/styles.css";` in parent styles.css
60
+ - TSX: `import ProductCard from "../../sub-components/ProductCard";`
61
+ - Sub-components that read MobX stores need `observer()`, others don't
62
+ - Sub-components can be shared across multiple parent sections
63
+ - NEVER create flat .tsx files inside a component folder
64
+
65
+ ## Key Patterns
66
+ - Root components are automatically reactive (ikas runtime uses autorun). Do NOT use observer() on root exports.
67
+ Pattern: `export function MySection({ title }: Props) { ... }` + `export default MySection;`
68
+ Only use observer() on extracted sub-components that independently read MobX stores.
69
+ - Null safety: storefront models can be null — always check before accessing
70
+ - Mutations: addItemToCart() etc. mutate MobX observables in-place — no return capture needed
71
+ - CSS: write plain class names — auto-scoped with .cc\_{componentId} at build time
72
+ - Events: use onInput (not onChange) for text inputs (Preact behavior)
73
+ - Imports: `import { addItemToCart, IkasProduct } from "@ikas/bp-storefront"`
74
+
75
+ ## No Static Text Rule
76
+ **CRITICAL: Never hardcode user-visible text in JSX.** All text strings (headings, button labels,
77
+ empty states, loading messages, form labels) MUST be TEXT props with defaultValues.
78
+ Wrong: `<h1>Sign In</h1>`
79
+ Correct: `<h1>{title}</h1>` with `title` as TEXT prop (defaultValue: "Sign In")
80
+ For button loading states, use two separate props (e.g., `submitButtonText` + `submittingButtonText`).
81
+ Group text props under a "Texts" propGroup when the component has 5+ props.
82
+
83
+ ## Sections vs Components
84
+ - Sections = page-level containers (Header, Hero, Product Grid, Footer)
85
+ Set "type": "section" via CLI. Use <section> root element. Props interface: Props.
86
+ **Sections MUST always include a `backgroundColor` COLOR prop** (default: `#ffffff`).
87
+ Apply via inline style: `style={backgroundColor ? { backgroundColor } : undefined}`
88
+ Consider also adding `textColor` COLOR props for text elements directly on the section background.
89
+ - Components = child elements inside sections (buttons, cards, badges)
90
+ Defaults to "component". Use <div> root element. Props interface: Props.
91
+
92
+ ## Prop Groups
93
+ Organize 5+ props into collapsible groups in editor sidebar.
94
+ - Define groups in `propGroups` on component in ikas.config.json
95
+ - Assign props via `groupId` on each prop
96
+ - Nest 1 level deep with `children`
97
+ - Group IDs must be unique within a component
98
+ - CLI: add-prop-group, update-prop-group, remove-prop-group
99
+ - Add prop to group: add-prop --group <groupId> or update-prop --group <groupId>
100
+
101
+ ## Build Verification
102
+ IMPORTANT: After completing any task, always run `npx ikas-component build` (or `npm run build`)
103
+ to check for TypeScript and build errors. Fix any errors before considering the task done.
@@ -0,0 +1,4 @@
1
+ node_modules/
2
+ dist/
3
+ .DS_Store
4
+ *.log