@beknurakhmed/webforge-cli 0.1.0 → 0.1.2

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 (324) hide show
  1. package/README.md +226 -212
  2. package/package.json +63 -63
  3. package/templates/extras/typescript/deps.json +6 -0
  4. package/templates/extras/typescript/react/tsconfig.json +21 -0
  5. package/templates/extras/typescript/vanilla/tsconfig.json +19 -0
  6. package/templates/extras/typescript/vue/tsconfig.json +20 -0
  7. package/templates/overlays/blog/angular/src/app/app.component.ts +100 -0
  8. package/templates/overlays/blog/angular/src/app/app.routes.ts +12 -0
  9. package/templates/overlays/blog/angular/src/app/components/blog-sidebar.component.ts +115 -0
  10. package/templates/overlays/blog/angular/src/app/components/post-card.component.ts +94 -0
  11. package/templates/overlays/blog/angular/src/app/pages/about.component.ts +114 -0
  12. package/templates/overlays/blog/angular/src/app/pages/category.component.ts +141 -0
  13. package/templates/overlays/blog/angular/src/app/pages/home.component.ts +143 -0
  14. package/templates/overlays/blog/angular/src/app/pages/post-detail.component.ts +196 -0
  15. package/templates/overlays/blog/angular/src/main.ts +10 -0
  16. package/templates/overlays/blog/nextjs/src/app/about/page.tsx +55 -0
  17. package/templates/overlays/blog/nextjs/src/app/category/[slug]/page.tsx +52 -0
  18. package/templates/overlays/blog/nextjs/src/app/components/BlogFooter.tsx +46 -0
  19. package/templates/overlays/blog/nextjs/src/app/components/BlogHeader.tsx +37 -0
  20. package/templates/overlays/blog/nextjs/src/app/components/BlogSidebar.tsx +56 -0
  21. package/templates/overlays/blog/nextjs/src/app/components/PostCard.tsx +42 -0
  22. package/templates/overlays/blog/nextjs/src/app/globals.css +158 -0
  23. package/templates/overlays/blog/nextjs/src/app/layout.tsx +20 -0
  24. package/templates/overlays/blog/nextjs/src/app/page.tsx +36 -0
  25. package/templates/overlays/blog/nextjs/src/app/post/[id]/page.tsx +78 -0
  26. package/templates/overlays/blog/nuxt/app.vue +27 -0
  27. package/templates/overlays/blog/nuxt/components/BlogFooter.vue +48 -0
  28. package/templates/overlays/blog/nuxt/components/BlogHeader.vue +55 -0
  29. package/templates/overlays/blog/nuxt/components/BlogSidebar.vue +144 -0
  30. package/templates/overlays/blog/nuxt/components/PostCard.vue +125 -0
  31. package/templates/overlays/blog/nuxt/layouts/default.vue +25 -0
  32. package/templates/overlays/blog/nuxt/pages/about.vue +161 -0
  33. package/templates/overlays/blog/nuxt/pages/category/[slug].vue +80 -0
  34. package/templates/overlays/blog/nuxt/pages/index.vue +54 -0
  35. package/templates/overlays/blog/nuxt/pages/post/[id].vue +158 -0
  36. package/templates/overlays/blog/react/src/App.css +58 -18
  37. package/templates/overlays/blog/react/src/App.tsx +16 -31
  38. package/templates/overlays/blog/react/src/components/BlogFooter.tsx +4 -2
  39. package/templates/overlays/blog/react/src/components/BlogHeader.tsx +12 -6
  40. package/templates/overlays/blog/react/src/components/BlogSidebar.tsx +9 -8
  41. package/templates/overlays/blog/react/src/components/Layout.tsx +17 -0
  42. package/templates/overlays/blog/react/src/components/PostCard.tsx +30 -0
  43. package/templates/overlays/blog/react/src/data/posts.ts +22 -0
  44. package/templates/overlays/blog/react/src/pages/About.tsx +33 -0
  45. package/templates/overlays/blog/react/src/pages/Category.tsx +29 -0
  46. package/templates/overlays/blog/react/src/pages/Home.tsx +18 -0
  47. package/templates/overlays/blog/react/src/pages/PostDetail.tsx +38 -0
  48. package/templates/overlays/blog/vanilla/src/main.ts +112 -0
  49. package/templates/overlays/blog/vanilla/src/pages/about.ts +106 -0
  50. package/templates/overlays/blog/vanilla/src/pages/category.ts +86 -0
  51. package/templates/overlays/blog/vanilla/src/pages/home.ts +103 -0
  52. package/templates/overlays/blog/vanilla/src/pages/post-detail.ts +108 -0
  53. package/templates/overlays/blog/vanilla/src/router.ts +33 -0
  54. package/templates/overlays/blog/vanilla/src/style.css +677 -0
  55. package/templates/overlays/blog/vue/src/App.vue +29 -0
  56. package/templates/overlays/blog/vue/src/components/BlogFooter.vue +8 -0
  57. package/templates/overlays/blog/vue/src/components/BlogHeader.vue +14 -0
  58. package/templates/overlays/blog/vue/src/components/BlogSidebar.vue +31 -0
  59. package/templates/overlays/blog/vue/src/components/PostCard.vue +17 -0
  60. package/templates/overlays/blog/vue/src/data.ts +82 -0
  61. package/templates/overlays/blog/vue/src/main.ts +6 -0
  62. package/templates/overlays/blog/vue/src/pages/About.vue +17 -0
  63. package/templates/overlays/blog/vue/src/pages/Category.vue +32 -0
  64. package/templates/overlays/blog/vue/src/pages/Home.vue +14 -0
  65. package/templates/overlays/blog/vue/src/pages/PostDetail.vue +22 -0
  66. package/templates/overlays/blog/vue/src/router.ts +19 -0
  67. package/templates/overlays/blog/vue/src/style.css +288 -0
  68. package/templates/overlays/crm/angular/src/app/app.component.ts +110 -0
  69. package/templates/overlays/crm/angular/src/app/app.routes.ts +12 -0
  70. package/templates/overlays/crm/angular/src/app/components/contacts-table.component.ts +98 -0
  71. package/templates/overlays/crm/angular/src/app/components/stats-cards.component.ts +63 -0
  72. package/templates/overlays/crm/angular/src/app/pages/contacts.component.ts +70 -0
  73. package/templates/overlays/crm/angular/src/app/pages/dashboard-home.component.ts +38 -0
  74. package/templates/overlays/crm/angular/src/app/pages/deals.component.ts +145 -0
  75. package/templates/overlays/crm/angular/src/app/pages/settings.component.ts +103 -0
  76. package/templates/overlays/crm/angular/src/main.ts +8 -0
  77. package/templates/overlays/crm/nextjs/src/app/components/ContactsTable.tsx +69 -0
  78. package/templates/overlays/crm/nextjs/src/app/components/Sidebar.tsx +45 -0
  79. package/templates/overlays/crm/nextjs/src/app/components/StatsCards.tsx +31 -0
  80. package/templates/overlays/crm/nextjs/src/app/contacts/page.tsx +111 -0
  81. package/templates/overlays/crm/nextjs/src/app/deals/page.tsx +111 -0
  82. package/templates/overlays/crm/nextjs/src/app/globals.css +165 -0
  83. package/templates/overlays/crm/nextjs/src/app/layout.tsx +20 -0
  84. package/templates/overlays/crm/nextjs/src/app/page.tsx +43 -0
  85. package/templates/overlays/crm/nextjs/src/app/settings/page.tsx +91 -0
  86. package/templates/overlays/crm/nuxt/app.vue +27 -0
  87. package/templates/overlays/crm/nuxt/components/ContactsTable.vue +140 -0
  88. package/templates/overlays/crm/nuxt/components/CrmSidebar.vue +97 -0
  89. package/templates/overlays/crm/nuxt/components/StatsCards.vue +63 -0
  90. package/templates/overlays/crm/nuxt/layouts/default.vue +21 -0
  91. package/templates/overlays/crm/nuxt/pages/contacts.vue +79 -0
  92. package/templates/overlays/crm/nuxt/pages/deals.vue +229 -0
  93. package/templates/overlays/crm/nuxt/pages/index.vue +186 -0
  94. package/templates/overlays/crm/nuxt/pages/settings.vue +233 -0
  95. package/templates/overlays/crm/react/src/App.css +49 -20
  96. package/templates/overlays/crm/react/src/App.tsx +16 -41
  97. package/templates/overlays/crm/react/src/components/ContactsTable.tsx +8 -8
  98. package/templates/overlays/crm/react/src/components/Layout.tsx +15 -0
  99. package/templates/overlays/crm/react/src/components/Sidebar.tsx +20 -14
  100. package/templates/overlays/crm/react/src/components/StatsCards.tsx +10 -12
  101. package/templates/overlays/crm/react/src/data/contacts.ts +19 -0
  102. package/templates/overlays/crm/react/src/pages/Contacts.tsx +32 -0
  103. package/templates/overlays/crm/react/src/pages/DashboardHome.tsx +44 -0
  104. package/templates/overlays/crm/react/src/pages/Deals.tsx +48 -0
  105. package/templates/overlays/crm/react/src/pages/Settings.tsx +35 -0
  106. package/templates/overlays/crm/vanilla/src/main.ts +95 -0
  107. package/templates/overlays/crm/vanilla/src/pages/contacts.ts +87 -0
  108. package/templates/overlays/crm/vanilla/src/pages/dashboard-home.ts +121 -0
  109. package/templates/overlays/crm/vanilla/src/pages/deals.ts +116 -0
  110. package/templates/overlays/crm/vanilla/src/pages/settings.ts +129 -0
  111. package/templates/overlays/crm/vanilla/src/router.ts +33 -0
  112. package/templates/overlays/crm/vanilla/src/style.css +766 -0
  113. package/templates/overlays/crm/vue/src/App.vue +25 -0
  114. package/templates/overlays/crm/vue/src/components/ContactsTable.vue +30 -0
  115. package/templates/overlays/crm/vue/src/components/CrmSidebar.vue +14 -0
  116. package/templates/overlays/crm/vue/src/components/StatsCards.vue +23 -0
  117. package/templates/overlays/crm/vue/src/data.ts +38 -0
  118. package/templates/overlays/crm/vue/src/main.ts +6 -0
  119. package/templates/overlays/crm/vue/src/pages/Contacts.vue +25 -0
  120. package/templates/overlays/crm/vue/src/pages/DashboardHome.vue +19 -0
  121. package/templates/overlays/crm/vue/src/pages/Deals.vue +34 -0
  122. package/templates/overlays/crm/vue/src/pages/Settings.vue +33 -0
  123. package/templates/overlays/crm/vue/src/router.ts +19 -0
  124. package/templates/overlays/crm/vue/src/style.css +272 -0
  125. package/templates/overlays/dashboard/angular/src/app/app.component.ts +135 -0
  126. package/templates/overlays/dashboard/angular/src/app/app.routes.ts +24 -0
  127. package/templates/overlays/dashboard/angular/src/app/components/chart-placeholder.component.ts +86 -0
  128. package/templates/overlays/dashboard/angular/src/app/components/data-table.component.ts +140 -0
  129. package/templates/overlays/dashboard/angular/src/app/components/kpi-cards.component.ts +120 -0
  130. package/templates/overlays/dashboard/angular/src/app/pages/analytics.component.ts +138 -0
  131. package/templates/overlays/dashboard/angular/src/app/pages/overview.component.ts +58 -0
  132. package/templates/overlays/dashboard/angular/src/app/pages/settings.component.ts +128 -0
  133. package/templates/overlays/dashboard/angular/src/app/pages/users.component.ts +153 -0
  134. package/templates/overlays/dashboard/angular/src/main.ts +10 -0
  135. package/templates/overlays/dashboard/nextjs/src/app/analytics/page.tsx +76 -0
  136. package/templates/overlays/dashboard/nextjs/src/app/components/ChartPlaceholder.tsx +58 -0
  137. package/templates/overlays/dashboard/nextjs/src/app/components/DataTable.tsx +60 -0
  138. package/templates/overlays/dashboard/nextjs/src/app/components/KPICards.tsx +31 -0
  139. package/templates/overlays/dashboard/nextjs/src/app/components/Sidebar.tsx +45 -0
  140. package/templates/overlays/dashboard/nextjs/src/app/globals.css +150 -0
  141. package/templates/overlays/dashboard/nextjs/src/app/layout.tsx +20 -0
  142. package/templates/overlays/dashboard/nextjs/src/app/page.tsx +20 -0
  143. package/templates/overlays/dashboard/nextjs/src/app/settings/page.tsx +118 -0
  144. package/templates/overlays/dashboard/nextjs/src/app/users/page.tsx +99 -0
  145. package/templates/overlays/dashboard/nuxt/app.vue +27 -0
  146. package/templates/overlays/dashboard/nuxt/components/ChartPlaceholder.vue +73 -0
  147. package/templates/overlays/dashboard/nuxt/components/DashSidebar.vue +97 -0
  148. package/templates/overlays/dashboard/nuxt/components/DataTable.vue +126 -0
  149. package/templates/overlays/dashboard/nuxt/components/KPICards.vue +76 -0
  150. package/templates/overlays/dashboard/nuxt/layouts/default.vue +21 -0
  151. package/templates/overlays/dashboard/nuxt/pages/analytics.vue +94 -0
  152. package/templates/overlays/dashboard/nuxt/pages/index.vue +49 -0
  153. package/templates/overlays/dashboard/nuxt/pages/settings.vue +239 -0
  154. package/templates/overlays/dashboard/nuxt/pages/users.vue +227 -0
  155. package/templates/overlays/dashboard/react/src/App.css +50 -24
  156. package/templates/overlays/dashboard/react/src/App.tsx +16 -22
  157. package/templates/overlays/dashboard/react/src/components/ChartPlaceholder.tsx +5 -2
  158. package/templates/overlays/dashboard/react/src/components/DataTable.tsx +9 -1
  159. package/templates/overlays/dashboard/react/src/components/KPICards.tsx +4 -4
  160. package/templates/overlays/dashboard/react/src/components/Layout.tsx +13 -0
  161. package/templates/overlays/dashboard/react/src/components/Sidebar.tsx +15 -10
  162. package/templates/overlays/dashboard/react/src/pages/Analytics.tsx +33 -0
  163. package/templates/overlays/dashboard/react/src/pages/Overview.tsx +23 -0
  164. package/templates/overlays/dashboard/react/src/pages/Settings.tsx +41 -0
  165. package/templates/overlays/dashboard/react/src/pages/Users.tsx +57 -0
  166. package/templates/overlays/dashboard/vanilla/src/main.ts +101 -0
  167. package/templates/overlays/dashboard/vanilla/src/pages/analytics.ts +99 -0
  168. package/templates/overlays/dashboard/vanilla/src/pages/overview.ts +60 -0
  169. package/templates/overlays/dashboard/vanilla/src/pages/settings.ts +118 -0
  170. package/templates/overlays/dashboard/vanilla/src/pages/users.ts +80 -0
  171. package/templates/overlays/dashboard/vanilla/src/router.ts +33 -0
  172. package/templates/overlays/dashboard/vanilla/src/style.css +654 -0
  173. package/templates/overlays/dashboard/vue/src/App.vue +12 -0
  174. package/templates/overlays/dashboard/vue/src/components/ChartPlaceholder.vue +34 -0
  175. package/templates/overlays/dashboard/vue/src/components/DashSidebar.vue +19 -0
  176. package/templates/overlays/dashboard/vue/src/components/DataTable.vue +34 -0
  177. package/templates/overlays/dashboard/vue/src/components/KPICards.vue +18 -0
  178. package/templates/overlays/dashboard/vue/src/main.ts +6 -0
  179. package/templates/overlays/dashboard/vue/src/pages/Analytics.vue +32 -0
  180. package/templates/overlays/dashboard/vue/src/pages/Overview.vue +17 -0
  181. package/templates/overlays/dashboard/vue/src/pages/Settings.vue +65 -0
  182. package/templates/overlays/dashboard/vue/src/pages/Users.vue +44 -0
  183. package/templates/overlays/dashboard/vue/src/router.ts +15 -0
  184. package/templates/overlays/dashboard/vue/src/style.css +447 -0
  185. package/templates/overlays/ecommerce/angular/src/app/app.component.ts +147 -0
  186. package/templates/overlays/ecommerce/angular/src/app/app.routes.ts +10 -0
  187. package/templates/overlays/ecommerce/angular/src/app/components/product-card.component.ts +94 -0
  188. package/templates/overlays/ecommerce/angular/src/app/data/products.ts +75 -0
  189. package/templates/overlays/ecommerce/angular/src/app/pages/cart.component.ts +169 -0
  190. package/templates/overlays/ecommerce/angular/src/app/pages/home.component.ts +96 -0
  191. package/templates/overlays/ecommerce/angular/src/app/pages/product-detail.component.ts +124 -0
  192. package/templates/overlays/ecommerce/angular/src/main.ts +10 -0
  193. package/templates/overlays/ecommerce/nextjs/src/app/cart/page.tsx +74 -0
  194. package/templates/overlays/ecommerce/nextjs/src/app/components/CartProvider.tsx +80 -0
  195. package/templates/overlays/ecommerce/nextjs/src/app/components/Footer.tsx +44 -0
  196. package/templates/overlays/ecommerce/nextjs/src/app/components/Header.tsx +27 -0
  197. package/templates/overlays/ecommerce/nextjs/src/app/components/ProductCard.tsx +23 -0
  198. package/templates/overlays/ecommerce/nextjs/src/app/globals.css +144 -0
  199. package/templates/overlays/ecommerce/nextjs/src/app/layout.tsx +23 -0
  200. package/templates/overlays/ecommerce/nextjs/src/app/page.tsx +73 -0
  201. package/templates/overlays/ecommerce/nextjs/src/app/product/[id]/page.tsx +63 -0
  202. package/templates/overlays/ecommerce/nuxt/app.vue +27 -0
  203. package/templates/overlays/ecommerce/nuxt/components/ProductCard.vue +77 -0
  204. package/templates/overlays/ecommerce/nuxt/components/StoreFooter.vue +47 -0
  205. package/templates/overlays/ecommerce/nuxt/components/StoreHeader.vue +91 -0
  206. package/templates/overlays/ecommerce/nuxt/layouts/default.vue +43 -0
  207. package/templates/overlays/ecommerce/nuxt/pages/cart.vue +268 -0
  208. package/templates/overlays/ecommerce/nuxt/pages/index.vue +154 -0
  209. package/templates/overlays/ecommerce/nuxt/pages/product/[id].vue +211 -0
  210. package/templates/overlays/ecommerce/react/src/App.css +71 -59
  211. package/templates/overlays/ecommerce/react/src/App.tsx +18 -44
  212. package/templates/overlays/ecommerce/react/src/components/Footer.tsx +2 -2
  213. package/templates/overlays/ecommerce/react/src/components/Header.tsx +15 -14
  214. package/templates/overlays/ecommerce/react/src/components/Layout.tsx +20 -0
  215. package/templates/overlays/ecommerce/react/src/components/ProductCard.tsx +28 -0
  216. package/templates/overlays/ecommerce/react/src/data/products.ts +23 -0
  217. package/templates/overlays/ecommerce/react/src/pages/Cart.tsx +51 -0
  218. package/templates/overlays/ecommerce/react/src/pages/Home.tsx +37 -0
  219. package/templates/overlays/ecommerce/react/src/pages/ProductDetail.tsx +38 -0
  220. package/templates/overlays/ecommerce/vanilla/src/main.ts +73 -0
  221. package/templates/overlays/ecommerce/vanilla/src/pages/cart.ts +73 -0
  222. package/templates/overlays/ecommerce/vanilla/src/pages/home.ts +71 -0
  223. package/templates/overlays/ecommerce/vanilla/src/pages/product-detail.ts +81 -0
  224. package/templates/overlays/ecommerce/vanilla/src/router.ts +33 -0
  225. package/templates/overlays/ecommerce/vanilla/src/style.css +522 -0
  226. package/templates/overlays/ecommerce/vue/src/App.vue +17 -32
  227. package/templates/overlays/ecommerce/vue/src/components/ProductCard.vue +25 -0
  228. package/templates/overlays/ecommerce/vue/src/components/StoreFooter.vue +6 -12
  229. package/templates/overlays/ecommerce/vue/src/components/StoreHeader.vue +5 -23
  230. package/templates/overlays/ecommerce/vue/src/data.ts +23 -0
  231. package/templates/overlays/ecommerce/vue/src/main.ts +6 -0
  232. package/templates/overlays/ecommerce/vue/src/pages/Cart.vue +34 -0
  233. package/templates/overlays/ecommerce/vue/src/pages/Home.vue +27 -0
  234. package/templates/overlays/ecommerce/vue/src/pages/ProductDetail.vue +27 -0
  235. package/templates/overlays/ecommerce/vue/src/router.ts +13 -0
  236. package/templates/overlays/ecommerce/vue/src/style.css +359 -0
  237. package/templates/overlays/portfolio/angular/src/app/app.component.ts +102 -0
  238. package/templates/overlays/portfolio/angular/src/app/app.routes.ts +12 -0
  239. package/templates/overlays/portfolio/angular/src/app/components/project-card.component.ts +86 -0
  240. package/templates/overlays/portfolio/angular/src/app/components/skills-grid.component.ts +88 -0
  241. package/templates/overlays/portfolio/angular/src/app/pages/about.component.ts +122 -0
  242. package/templates/overlays/portfolio/angular/src/app/pages/contact.component.ts +131 -0
  243. package/templates/overlays/portfolio/angular/src/app/pages/home.component.ts +207 -0
  244. package/templates/overlays/portfolio/angular/src/app/pages/projects.component.ts +150 -0
  245. package/templates/overlays/portfolio/angular/src/main.ts +10 -0
  246. package/templates/overlays/portfolio/nextjs/src/app/about/page.tsx +70 -0
  247. package/templates/overlays/portfolio/nextjs/src/app/components/Footer.tsx +37 -0
  248. package/templates/overlays/portfolio/nextjs/src/app/components/Navbar.tsx +37 -0
  249. package/templates/overlays/portfolio/nextjs/src/app/components/ProjectCard.tsx +35 -0
  250. package/templates/overlays/portfolio/nextjs/src/app/components/SkillsGrid.tsx +45 -0
  251. package/templates/overlays/portfolio/nextjs/src/app/contact/page.tsx +138 -0
  252. package/templates/overlays/portfolio/nextjs/src/app/globals.css +197 -0
  253. package/templates/overlays/portfolio/nextjs/src/app/layout.tsx +20 -0
  254. package/templates/overlays/portfolio/nextjs/src/app/page.tsx +60 -0
  255. package/templates/overlays/portfolio/nextjs/src/app/projects/page.tsx +56 -0
  256. package/templates/overlays/portfolio/nuxt/app.vue +27 -0
  257. package/templates/overlays/portfolio/nuxt/components/PortfolioFooter.vue +49 -0
  258. package/templates/overlays/portfolio/nuxt/components/PortfolioNav.vue +77 -0
  259. package/templates/overlays/portfolio/nuxt/components/ProjectCard.vue +102 -0
  260. package/templates/overlays/portfolio/nuxt/components/SkillsGrid.vue +89 -0
  261. package/templates/overlays/portfolio/nuxt/layouts/default.vue +21 -0
  262. package/templates/overlays/portfolio/nuxt/pages/about.vue +179 -0
  263. package/templates/overlays/portfolio/nuxt/pages/contact.vue +278 -0
  264. package/templates/overlays/portfolio/nuxt/pages/index.vue +160 -0
  265. package/templates/overlays/portfolio/nuxt/pages/projects.vue +116 -0
  266. package/templates/overlays/portfolio/react/src/App.css +54 -27
  267. package/templates/overlays/portfolio/react/src/App.tsx +16 -12
  268. package/templates/overlays/portfolio/react/src/components/Layout.tsx +17 -0
  269. package/templates/overlays/portfolio/react/src/components/Navbar.tsx +30 -0
  270. package/templates/overlays/portfolio/react/src/components/PortfolioFooter.tsx +5 -3
  271. package/templates/overlays/portfolio/react/src/components/ProjectCard.tsx +24 -0
  272. package/templates/overlays/portfolio/react/src/components/SkillsGrid.tsx +20 -0
  273. package/templates/overlays/portfolio/react/src/data/projects.ts +25 -0
  274. package/templates/overlays/portfolio/react/src/pages/About.tsx +43 -0
  275. package/templates/overlays/portfolio/react/src/pages/Contact.tsx +48 -0
  276. package/templates/overlays/portfolio/react/src/pages/Home.tsx +44 -0
  277. package/templates/overlays/portfolio/react/src/pages/Projects.tsx +36 -0
  278. package/templates/overlays/portfolio/vanilla/src/main.ts +58 -0
  279. package/templates/overlays/portfolio/vanilla/src/pages/about.ts +146 -0
  280. package/templates/overlays/portfolio/vanilla/src/pages/contact.ts +159 -0
  281. package/templates/overlays/portfolio/vanilla/src/pages/home.ts +123 -0
  282. package/templates/overlays/portfolio/vanilla/src/pages/projects.ts +89 -0
  283. package/templates/overlays/portfolio/vanilla/src/router.ts +33 -0
  284. package/templates/overlays/portfolio/vanilla/src/style.css +909 -0
  285. package/templates/overlays/portfolio/vue/src/App.vue +25 -0
  286. package/templates/overlays/portfolio/vue/src/components/PortfolioFooter.vue +14 -0
  287. package/templates/overlays/portfolio/vue/src/components/PortfolioNav.vue +16 -0
  288. package/templates/overlays/portfolio/vue/src/components/ProjectCard.vue +18 -0
  289. package/templates/overlays/portfolio/vue/src/components/SkillsGrid.vue +14 -0
  290. package/templates/overlays/portfolio/vue/src/data.ts +78 -0
  291. package/templates/overlays/portfolio/vue/src/main.ts +6 -0
  292. package/templates/overlays/portfolio/vue/src/pages/About.vue +30 -0
  293. package/templates/overlays/portfolio/vue/src/pages/Contact.vue +47 -0
  294. package/templates/overlays/portfolio/vue/src/pages/Home.vue +27 -0
  295. package/templates/overlays/portfolio/vue/src/pages/Projects.vue +33 -0
  296. package/templates/overlays/portfolio/vue/src/router.ts +19 -0
  297. package/templates/overlays/portfolio/vue/src/style.css +404 -0
  298. package/templates/react/package.json +23 -19
  299. package/templates/react/tsconfig.json +20 -0
  300. package/templates/styling/tailwind/deps.json +7 -6
  301. package/templates/styling/tailwind/nextjs/postcss.config.mjs +7 -0
  302. package/templates/styling/tailwind/nextjs/src/app/globals.css +1 -0
  303. package/templates/styling/tailwind/react/src/index.css +1 -0
  304. package/templates/styling/tailwind/react/vite.config.ts +7 -0
  305. package/templates/styling/tailwind/vanilla/src/style.css +1 -0
  306. package/templates/styling/tailwind/vanilla/vite.config.ts +6 -0
  307. package/templates/styling/tailwind/vue/src/style.css +1 -0
  308. package/templates/styling/tailwind/vue/vite.config.ts +7 -0
  309. package/templates/vanilla/package.json +15 -14
  310. package/templates/vanilla/tsconfig.json +19 -0
  311. package/templates/vue/package.json +21 -18
  312. package/templates/vue/tsconfig.json +20 -0
  313. package/templates/overlays/blog/react/src/components/PostList.tsx +0 -27
  314. package/templates/overlays/crm/react/src/components/Filters.tsx +0 -22
  315. package/templates/overlays/ecommerce/react/src/components/Cart.tsx +0 -47
  316. package/templates/overlays/ecommerce/react/src/components/ProductGrid.tsx +0 -32
  317. package/templates/overlays/ecommerce/vue/src/components/CartPanel.vue +0 -46
  318. package/templates/overlays/ecommerce/vue/src/components/ProductGrid.vue +0 -40
  319. package/templates/overlays/portfolio/react/src/components/ContactForm.tsx +0 -29
  320. package/templates/overlays/portfolio/react/src/components/HeroSection.tsx +0 -24
  321. package/templates/overlays/portfolio/react/src/components/Projects.tsx +0 -33
  322. package/templates/overlays/portfolio/react/src/components/Skills.tsx +0 -27
  323. package/templates/styling/tailwind/config/postcss.config.js +0 -5
  324. package/templates/styling/tailwind/config/tailwind.config.js +0 -11
@@ -0,0 +1,77 @@
1
+ <script setup lang="ts">
2
+ defineProps<{
3
+ product: {
4
+ id: number;
5
+ name: string;
6
+ price: number;
7
+ image: string;
8
+ category: string;
9
+ description: string;
10
+ };
11
+ }>();
12
+ </script>
13
+
14
+ <template>
15
+ <NuxtLink :to="`/product/${product.id}`" class="product-card">
16
+ <div class="card-image">
17
+ <span class="emoji">{{ product.image }}</span>
18
+ </div>
19
+ <div class="card-body">
20
+ <span class="card-category">{{ product.category }}</span>
21
+ <h3 class="card-name">{{ product.name }}</h3>
22
+ <p class="card-price">${{ product.price.toFixed(2) }}</p>
23
+ </div>
24
+ </NuxtLink>
25
+ </template>
26
+
27
+ <style scoped>
28
+ .product-card {
29
+ background: white;
30
+ border-radius: 12px;
31
+ overflow: hidden;
32
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
33
+ transition: transform 0.2s, box-shadow 0.2s;
34
+ display: block;
35
+ }
36
+
37
+ .product-card:hover {
38
+ transform: translateY(-4px);
39
+ box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
40
+ }
41
+
42
+ .card-image {
43
+ background: #f3f4f6;
44
+ display: flex;
45
+ align-items: center;
46
+ justify-content: center;
47
+ padding: 2rem;
48
+ }
49
+
50
+ .emoji {
51
+ font-size: 4rem;
52
+ }
53
+
54
+ .card-body {
55
+ padding: 1.25rem;
56
+ }
57
+
58
+ .card-category {
59
+ font-size: 0.75rem;
60
+ color: #4f46e5;
61
+ font-weight: 600;
62
+ text-transform: uppercase;
63
+ letter-spacing: 0.05em;
64
+ }
65
+
66
+ .card-name {
67
+ font-size: 1.05rem;
68
+ color: #111827;
69
+ margin: 0.35rem 0 0.5rem;
70
+ }
71
+
72
+ .card-price {
73
+ font-size: 1.15rem;
74
+ font-weight: 700;
75
+ color: #4f46e5;
76
+ }
77
+ </style>
@@ -0,0 +1,47 @@
1
+ <template>
2
+ <footer class="store-footer">
3
+ <div class="footer-inner">
4
+ <p>&copy; 2024 {{projectName}}. All rights reserved.</p>
5
+ <div class="footer-links">
6
+ <NuxtLink to="/">Home</NuxtLink>
7
+ <NuxtLink to="/cart">Cart</NuxtLink>
8
+ </div>
9
+ </div>
10
+ </footer>
11
+ </template>
12
+
13
+ <style scoped>
14
+ .store-footer {
15
+ background: #111827;
16
+ color: #9ca3af;
17
+ padding: 1.5rem 1rem;
18
+ margin-top: auto;
19
+ }
20
+
21
+ .footer-inner {
22
+ max-width: 1200px;
23
+ margin: 0 auto;
24
+ display: flex;
25
+ align-items: center;
26
+ justify-content: space-between;
27
+ }
28
+
29
+ .footer-inner p {
30
+ font-size: 0.875rem;
31
+ }
32
+
33
+ .footer-links {
34
+ display: flex;
35
+ gap: 1.25rem;
36
+ }
37
+
38
+ .footer-links a {
39
+ color: #9ca3af;
40
+ font-size: 0.875rem;
41
+ transition: color 0.2s;
42
+ }
43
+
44
+ .footer-links a:hover {
45
+ color: white;
46
+ }
47
+ </style>
@@ -0,0 +1,91 @@
1
+ <script setup lang="ts">
2
+ defineProps<{
3
+ cartCount: number;
4
+ }>();
5
+ </script>
6
+
7
+ <template>
8
+ <header class="store-header">
9
+ <div class="header-inner">
10
+ <NuxtLink to="/" class="logo">🛍️ {{projectName}}</NuxtLink>
11
+ <nav class="header-nav">
12
+ <NuxtLink to="/" class="nav-link">Home</NuxtLink>
13
+ <NuxtLink to="/cart" class="cart-link">
14
+ 🛒 Cart
15
+ <span v-if="cartCount > 0" class="cart-badge">{{ cartCount }}</span>
16
+ </NuxtLink>
17
+ </nav>
18
+ </div>
19
+ </header>
20
+ </template>
21
+
22
+ <style scoped>
23
+ .store-header {
24
+ background: #111827;
25
+ color: white;
26
+ padding: 0 1rem;
27
+ position: sticky;
28
+ top: 0;
29
+ z-index: 100;
30
+ box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
31
+ }
32
+
33
+ .header-inner {
34
+ max-width: 1200px;
35
+ margin: 0 auto;
36
+ display: flex;
37
+ align-items: center;
38
+ justify-content: space-between;
39
+ height: 64px;
40
+ }
41
+
42
+ .logo {
43
+ font-size: 1.35rem;
44
+ font-weight: 700;
45
+ color: white;
46
+ }
47
+
48
+ .header-nav {
49
+ display: flex;
50
+ align-items: center;
51
+ gap: 1.5rem;
52
+ }
53
+
54
+ .nav-link {
55
+ color: #d1d5db;
56
+ font-weight: 500;
57
+ transition: color 0.2s;
58
+ }
59
+
60
+ .nav-link:hover {
61
+ color: white;
62
+ }
63
+
64
+ .cart-link {
65
+ color: #d1d5db;
66
+ font-weight: 500;
67
+ position: relative;
68
+ display: flex;
69
+ align-items: center;
70
+ gap: 0.35rem;
71
+ transition: color 0.2s;
72
+ }
73
+
74
+ .cart-link:hover {
75
+ color: white;
76
+ }
77
+
78
+ .cart-badge {
79
+ background: #4f46e5;
80
+ color: white;
81
+ font-size: 0.7rem;
82
+ font-weight: 700;
83
+ min-width: 20px;
84
+ height: 20px;
85
+ border-radius: 10px;
86
+ display: flex;
87
+ align-items: center;
88
+ justify-content: center;
89
+ padding: 0 5px;
90
+ }
91
+ </style>
@@ -0,0 +1,43 @@
1
+ <script setup lang="ts">
2
+ export interface Product {
3
+ id: number;
4
+ name: string;
5
+ price: number;
6
+ image: string;
7
+ category: string;
8
+ description: string;
9
+ }
10
+
11
+ export interface CartItem extends Product {
12
+ quantity: number;
13
+ }
14
+
15
+ const cart = useState<CartItem[]>('cart', () => []);
16
+ const cartCount = computed(() => cart.value.reduce((sum, i) => sum + i.quantity, 0));
17
+ </script>
18
+
19
+ <template>
20
+ <div class="store-layout">
21
+ <StoreHeader :cart-count="cartCount" />
22
+ <main class="store-main">
23
+ <slot />
24
+ </main>
25
+ <StoreFooter />
26
+ </div>
27
+ </template>
28
+
29
+ <style>
30
+ .store-layout {
31
+ min-height: 100vh;
32
+ display: flex;
33
+ flex-direction: column;
34
+ }
35
+
36
+ .store-main {
37
+ flex: 1;
38
+ max-width: 1200px;
39
+ width: 100%;
40
+ margin: 0 auto;
41
+ padding: 2rem 1rem;
42
+ }
43
+ </style>
@@ -0,0 +1,268 @@
1
+ <script setup lang="ts">
2
+ interface Product {
3
+ id: number;
4
+ name: string;
5
+ price: number;
6
+ image: string;
7
+ category: string;
8
+ description: string;
9
+ }
10
+
11
+ interface CartItem extends Product {
12
+ quantity: number;
13
+ }
14
+
15
+ const cart = useState<CartItem[]>('cart');
16
+
17
+ const total = computed(() =>
18
+ cart.value.reduce((sum, item) => sum + item.price * item.quantity, 0)
19
+ );
20
+
21
+ function removeItem(id: number) {
22
+ cart.value = cart.value.filter(item => item.id !== id);
23
+ }
24
+
25
+ function updateQuantity(id: number, delta: number) {
26
+ const item = cart.value.find(i => i.id === id);
27
+ if (item) {
28
+ item.quantity += delta;
29
+ if (item.quantity <= 0) {
30
+ removeItem(id);
31
+ }
32
+ }
33
+ }
34
+ </script>
35
+
36
+ <template>
37
+ <div class="cart-page">
38
+ <h1 class="cart-title">Shopping Cart</h1>
39
+
40
+ <div v-if="cart.length > 0" class="cart-content">
41
+ <div class="cart-items">
42
+ <div v-for="item in cart" :key="item.id" class="cart-item">
43
+ <span class="item-image">{{ item.image }}</span>
44
+ <div class="item-details">
45
+ <h3>{{ item.name }}</h3>
46
+ <p class="item-price">${{ item.price.toFixed(2) }}</p>
47
+ </div>
48
+ <div class="item-quantity">
49
+ <button @click="updateQuantity(item.id, -1)">-</button>
50
+ <span>{{ item.quantity }}</span>
51
+ <button @click="updateQuantity(item.id, 1)">+</button>
52
+ </div>
53
+ <p class="item-subtotal">${{ (item.price * item.quantity).toFixed(2) }}</p>
54
+ <button class="remove-btn" @click="removeItem(item.id)">✕</button>
55
+ </div>
56
+ </div>
57
+
58
+ <div class="cart-summary">
59
+ <h2>Order Summary</h2>
60
+ <div class="summary-row">
61
+ <span>Subtotal</span>
62
+ <span>${{ total.toFixed(2) }}</span>
63
+ </div>
64
+ <div class="summary-row">
65
+ <span>Shipping</span>
66
+ <span>Free</span>
67
+ </div>
68
+ <div class="summary-row total">
69
+ <span>Total</span>
70
+ <span>${{ total.toFixed(2) }}</span>
71
+ </div>
72
+ <button class="checkout-btn">Proceed to Checkout</button>
73
+ </div>
74
+ </div>
75
+
76
+ <div v-else class="empty-cart">
77
+ <p class="empty-icon">🛒</p>
78
+ <h2>Your cart is empty</h2>
79
+ <p>Start adding some products!</p>
80
+ <NuxtLink to="/" class="continue-btn">Continue Shopping</NuxtLink>
81
+ </div>
82
+ </div>
83
+ </template>
84
+
85
+ <style scoped>
86
+ .cart-title {
87
+ font-size: 2rem;
88
+ color: #111827;
89
+ margin-bottom: 2rem;
90
+ }
91
+
92
+ .cart-content {
93
+ display: grid;
94
+ grid-template-columns: 1fr 350px;
95
+ gap: 2rem;
96
+ align-items: start;
97
+ }
98
+
99
+ .cart-items {
100
+ display: flex;
101
+ flex-direction: column;
102
+ gap: 1rem;
103
+ }
104
+
105
+ .cart-item {
106
+ display: flex;
107
+ align-items: center;
108
+ gap: 1rem;
109
+ background: white;
110
+ padding: 1.25rem;
111
+ border-radius: 10px;
112
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
113
+ }
114
+
115
+ .item-image {
116
+ font-size: 2.5rem;
117
+ }
118
+
119
+ .item-details {
120
+ flex: 1;
121
+ }
122
+
123
+ .item-details h3 {
124
+ color: #111827;
125
+ font-size: 1rem;
126
+ margin-bottom: 0.25rem;
127
+ }
128
+
129
+ .item-price {
130
+ color: #6b7280;
131
+ font-size: 0.9rem;
132
+ }
133
+
134
+ .item-quantity {
135
+ display: flex;
136
+ align-items: center;
137
+ border: 1px solid #d1d5db;
138
+ border-radius: 6px;
139
+ overflow: hidden;
140
+ }
141
+
142
+ .item-quantity button {
143
+ background: #f3f4f6;
144
+ border: none;
145
+ padding: 0.35rem 0.75rem;
146
+ cursor: pointer;
147
+ font-size: 0.9rem;
148
+ }
149
+
150
+ .item-quantity button:hover {
151
+ background: #e5e7eb;
152
+ }
153
+
154
+ .item-quantity span {
155
+ padding: 0.35rem 0.75rem;
156
+ font-weight: 600;
157
+ font-size: 0.9rem;
158
+ }
159
+
160
+ .item-subtotal {
161
+ font-weight: 700;
162
+ color: #111827;
163
+ min-width: 70px;
164
+ text-align: right;
165
+ }
166
+
167
+ .remove-btn {
168
+ background: none;
169
+ border: none;
170
+ color: #9ca3af;
171
+ cursor: pointer;
172
+ font-size: 1.1rem;
173
+ padding: 0.25rem;
174
+ }
175
+
176
+ .remove-btn:hover {
177
+ color: #ef4444;
178
+ }
179
+
180
+ .cart-summary {
181
+ background: white;
182
+ padding: 1.5rem;
183
+ border-radius: 10px;
184
+ box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
185
+ }
186
+
187
+ .cart-summary h2 {
188
+ font-size: 1.25rem;
189
+ color: #111827;
190
+ margin-bottom: 1.25rem;
191
+ padding-bottom: 0.75rem;
192
+ border-bottom: 1px solid #e5e7eb;
193
+ }
194
+
195
+ .summary-row {
196
+ display: flex;
197
+ justify-content: space-between;
198
+ padding: 0.5rem 0;
199
+ color: #6b7280;
200
+ }
201
+
202
+ .summary-row.total {
203
+ font-weight: 700;
204
+ font-size: 1.2rem;
205
+ color: #111827;
206
+ border-top: 1px solid #e5e7eb;
207
+ margin-top: 0.75rem;
208
+ padding-top: 1rem;
209
+ }
210
+
211
+ .checkout-btn {
212
+ width: 100%;
213
+ background: #4f46e5;
214
+ color: white;
215
+ border: none;
216
+ padding: 0.875rem;
217
+ border-radius: 8px;
218
+ font-size: 1rem;
219
+ font-weight: 600;
220
+ cursor: pointer;
221
+ margin-top: 1.25rem;
222
+ transition: background 0.2s;
223
+ }
224
+
225
+ .checkout-btn:hover {
226
+ background: #4338ca;
227
+ }
228
+
229
+ .empty-cart {
230
+ text-align: center;
231
+ padding: 4rem 0;
232
+ }
233
+
234
+ .empty-icon {
235
+ font-size: 4rem;
236
+ margin-bottom: 1rem;
237
+ }
238
+
239
+ .empty-cart h2 {
240
+ color: #111827;
241
+ margin-bottom: 0.5rem;
242
+ }
243
+
244
+ .empty-cart p {
245
+ color: #6b7280;
246
+ margin-bottom: 1.5rem;
247
+ }
248
+
249
+ .continue-btn {
250
+ display: inline-block;
251
+ background: #4f46e5;
252
+ color: white;
253
+ padding: 0.75rem 1.5rem;
254
+ border-radius: 8px;
255
+ font-weight: 600;
256
+ transition: background 0.2s;
257
+ }
258
+
259
+ .continue-btn:hover {
260
+ background: #4338ca;
261
+ }
262
+
263
+ @media (max-width: 768px) {
264
+ .cart-content {
265
+ grid-template-columns: 1fr;
266
+ }
267
+ }
268
+ </style>
@@ -0,0 +1,154 @@
1
+ <script setup lang="ts">
2
+ interface Product {
3
+ id: number;
4
+ name: string;
5
+ price: number;
6
+ image: string;
7
+ category: string;
8
+ description: string;
9
+ }
10
+
11
+ const products: Product[] = [
12
+ { id: 1, name: 'Wireless Headphones', price: 79.99, image: '🎧', category: 'Electronics', description: 'Premium wireless headphones with noise cancellation.' },
13
+ { id: 2, name: 'Running Shoes', price: 129.99, image: '👟', category: 'Sports', description: 'Lightweight running shoes for daily training.' },
14
+ { id: 3, name: 'Coffee Maker', price: 49.99, image: '☕', category: 'Home', description: 'Programmable coffee maker with thermal carafe.' },
15
+ { id: 4, name: 'Backpack', price: 59.99, image: '🎒', category: 'Accessories', description: 'Water-resistant laptop backpack.' },
16
+ { id: 5, name: 'Smartwatch', price: 199.99, image: '⌚', category: 'Electronics', description: 'Fitness tracking smartwatch.' },
17
+ { id: 6, name: 'Desk Lamp', price: 34.99, image: '💡', category: 'Home', description: 'LED desk lamp with adjustable brightness.' },
18
+ { id: 7, name: 'Yoga Mat', price: 29.99, image: '🧘', category: 'Sports', description: 'Non-slip yoga mat with carrying strap.' },
19
+ { id: 8, name: 'Sunglasses', price: 89.99, image: '🕶️', category: 'Accessories', description: 'Polarized sunglasses with UV protection.' },
20
+ ];
21
+
22
+ const search = ref('');
23
+ const selectedCategory = ref('All');
24
+
25
+ const categories = computed(() => ['All', ...new Set(products.map(p => p.category))]);
26
+
27
+ const filteredProducts = computed(() => {
28
+ return products.filter(p => {
29
+ const matchSearch = p.name.toLowerCase().includes(search.value.toLowerCase());
30
+ const matchCategory = selectedCategory.value === 'All' || p.category === selectedCategory.value;
31
+ return matchSearch && matchCategory;
32
+ });
33
+ });
34
+ </script>
35
+
36
+ <template>
37
+ <div class="shop-page">
38
+ <div class="shop-hero">
39
+ <h1>Welcome to Our Store</h1>
40
+ <p>Discover amazing products at great prices</p>
41
+ </div>
42
+
43
+ <div class="shop-controls">
44
+ <input
45
+ v-model="search"
46
+ type="text"
47
+ placeholder="Search products..."
48
+ class="search-input"
49
+ />
50
+ <div class="category-filters">
51
+ <button
52
+ v-for="cat in categories"
53
+ :key="cat"
54
+ :class="['cat-btn', { active: selectedCategory === cat }]"
55
+ @click="selectedCategory = cat"
56
+ >
57
+ {{ cat }}
58
+ </button>
59
+ </div>
60
+ </div>
61
+
62
+ <div class="product-grid">
63
+ <ProductCard
64
+ v-for="product in filteredProducts"
65
+ :key="product.id"
66
+ :product="product"
67
+ />
68
+ </div>
69
+
70
+ <p v-if="filteredProducts.length === 0" class="no-results">
71
+ No products found matching your search.
72
+ </p>
73
+ </div>
74
+ </template>
75
+
76
+ <style scoped>
77
+ .shop-hero {
78
+ text-align: center;
79
+ padding: 2rem 0 1.5rem;
80
+ }
81
+
82
+ .shop-hero h1 {
83
+ font-size: 2rem;
84
+ color: #111827;
85
+ margin-bottom: 0.5rem;
86
+ }
87
+
88
+ .shop-hero p {
89
+ color: #6b7280;
90
+ font-size: 1.1rem;
91
+ }
92
+
93
+ .shop-controls {
94
+ display: flex;
95
+ flex-direction: column;
96
+ gap: 1rem;
97
+ margin-bottom: 2rem;
98
+ }
99
+
100
+ .search-input {
101
+ width: 100%;
102
+ padding: 0.75rem 1rem;
103
+ border: 1px solid #d1d5db;
104
+ border-radius: 8px;
105
+ font-size: 1rem;
106
+ outline: none;
107
+ transition: border-color 0.2s;
108
+ }
109
+
110
+ .search-input:focus {
111
+ border-color: #4f46e5;
112
+ box-shadow: 0 0 0 3px rgba(79, 70, 229, 0.1);
113
+ }
114
+
115
+ .category-filters {
116
+ display: flex;
117
+ gap: 0.5rem;
118
+ flex-wrap: wrap;
119
+ }
120
+
121
+ .cat-btn {
122
+ padding: 0.5rem 1rem;
123
+ border: 1px solid #d1d5db;
124
+ border-radius: 20px;
125
+ background: white;
126
+ cursor: pointer;
127
+ font-size: 0.875rem;
128
+ transition: all 0.2s;
129
+ }
130
+
131
+ .cat-btn:hover {
132
+ border-color: #4f46e5;
133
+ color: #4f46e5;
134
+ }
135
+
136
+ .cat-btn.active {
137
+ background: #4f46e5;
138
+ color: white;
139
+ border-color: #4f46e5;
140
+ }
141
+
142
+ .product-grid {
143
+ display: grid;
144
+ grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
145
+ gap: 1.5rem;
146
+ }
147
+
148
+ .no-results {
149
+ text-align: center;
150
+ color: #6b7280;
151
+ padding: 3rem 0;
152
+ font-size: 1.1rem;
153
+ }
154
+ </style>