@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
@@ -1,47 +0,0 @@
1
- import type { CartItem } from '../App';
2
-
3
- interface CartProps {
4
- items: CartItem[];
5
- onRemove: (id: number) => void;
6
- onClose: () => void;
7
- }
8
-
9
- export function Cart({ items, onRemove, onClose }: CartProps) {
10
- const total = items.reduce((sum, item) => sum + item.price * item.quantity, 0);
11
-
12
- return (
13
- <div className="cart-overlay" onClick={onClose}>
14
- <div className="cart-panel" onClick={(e) => e.stopPropagation()}>
15
- <div className="cart-header">
16
- <h2>Shopping Cart</h2>
17
- <button className="cart-close" onClick={onClose}>X</button>
18
- </div>
19
- {items.length === 0 ? (
20
- <p className="cart-empty">Your cart is empty</p>
21
- ) : (
22
- <>
23
- <div className="cart-items">
24
- {items.map((item) => (
25
- <div key={item.id} className="cart-item">
26
- <span className="cart-item-image">{item.image}</span>
27
- <div className="cart-item-info">
28
- <h4>{item.name}</h4>
29
- <p>Qty: {item.quantity} x ${item.price.toFixed(2)}</p>
30
- </div>
31
- <button className="cart-item-remove" onClick={() => onRemove(item.id)}>Remove</button>
32
- </div>
33
- ))}
34
- </div>
35
- <div className="cart-footer">
36
- <div className="cart-total">
37
- <span>Total:</span>
38
- <strong>${total.toFixed(2)}</strong>
39
- </div>
40
- <button className="checkout-btn">Checkout</button>
41
- </div>
42
- </>
43
- )}
44
- </div>
45
- </div>
46
- );
47
- }
@@ -1,32 +0,0 @@
1
- import type { Product } from '../App';
2
-
3
- interface ProductGridProps {
4
- products: Product[];
5
- onAddToCart: (product: Product) => void;
6
- }
7
-
8
- export function ProductGrid({ products, onAddToCart }: ProductGridProps) {
9
- return (
10
- <section className="product-section">
11
- <h2>All Products</h2>
12
- <div className="product-grid">
13
- {products.map((product) => (
14
- <div key={product.id} className="product-card">
15
- <div className="product-image">{product.image}</div>
16
- <div className="product-info">
17
- <span className="product-category">{product.category}</span>
18
- <h3>{product.name}</h3>
19
- <p>{product.description}</p>
20
- <div className="product-footer">
21
- <span className="product-price">${product.price.toFixed(2)}</span>
22
- <button className="add-to-cart" onClick={() => onAddToCart(product)}>
23
- Add to Cart
24
- </button>
25
- </div>
26
- </div>
27
- </div>
28
- ))}
29
- </div>
30
- </section>
31
- );
32
- }
@@ -1,46 +0,0 @@
1
- <script setup lang="ts">
2
- import { computed } from 'vue';
3
- interface CartItem { id: number; name: string; price: number; image: string; quantity: number; }
4
- const props = defineProps<{ items: CartItem[] }>();
5
- defineEmits<{ remove: [id: number]; close: [] }>();
6
- const total = computed(() => props.items.reduce((sum, item) => sum + item.price * item.quantity, 0));
7
- </script>
8
-
9
- <template>
10
- <div class="cart-overlay" @click="$emit('close')">
11
- <div class="cart-panel" @click.stop>
12
- <div class="cart-header"><h2>Shopping Cart</h2><button @click="$emit('close')">X</button></div>
13
- <p v-if="items.length === 0" class="cart-empty">Your cart is empty</p>
14
- <template v-else>
15
- <div class="cart-items">
16
- <div v-for="item in items" :key="item.id" class="cart-item">
17
- <span>{{ item.image }}</span>
18
- <div><h4>{{ item.name }}</h4><p>Qty: {{ item.quantity }} x ${{ item.price.toFixed(2) }}</p></div>
19
- <button @click="$emit('remove', item.id)">Remove</button>
20
- </div>
21
- </div>
22
- <div class="cart-footer">
23
- <div class="cart-total"><span>Total:</span><strong>${{ total.toFixed(2) }}</strong></div>
24
- <button class="checkout-btn">Checkout</button>
25
- </div>
26
- </template>
27
- </div>
28
- </div>
29
- </template>
30
-
31
- <style scoped>
32
- .cart-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 50; }
33
- .cart-panel { position: fixed; top: 0; right: 0; bottom: 0; width: 400px; max-width: 100%; background: white; box-shadow: -4px 0 25px rgba(0,0,0,0.1); display: flex; flex-direction: column; }
34
- .cart-header { display: flex; justify-content: space-between; align-items: center; padding: 1.5rem; border-bottom: 1px solid #e5e7eb; }
35
- .cart-header h2 { margin: 0; font-size: 1.25rem; }
36
- .cart-header button { background: none; border: none; font-size: 1.25rem; cursor: pointer; }
37
- .cart-empty { text-align: center; padding: 3rem; color: #9ca3af; }
38
- .cart-items { flex: 1; overflow-y: auto; padding: 1rem; }
39
- .cart-item { display: flex; align-items: center; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid #f3f4f6; }
40
- .cart-item h4 { margin: 0; font-size: 0.95rem; }
41
- .cart-item p { color: #6b7280; font-size: 0.85rem; margin: 0; }
42
- .cart-item button { background: none; border: none; color: #ef4444; cursor: pointer; margin-left: auto; }
43
- .cart-footer { padding: 1.5rem; border-top: 1px solid #e5e7eb; }
44
- .cart-total { display: flex; justify-content: space-between; margin-bottom: 1rem; font-size: 1.1rem; }
45
- .checkout-btn { width: 100%; background: #4f46e5; color: white; border: none; padding: 0.75rem; border-radius: 8px; font-size: 1rem; font-weight: 600; cursor: pointer; }
46
- </style>
@@ -1,40 +0,0 @@
1
- <script setup lang="ts">
2
- interface Product { id: number; name: string; price: number; image: string; category: string; description: string; }
3
- defineProps<{ products: Product[] }>();
4
- defineEmits<{ 'add-to-cart': [product: Product] }>();
5
- </script>
6
-
7
- <template>
8
- <section class="product-section">
9
- <h2>All Products</h2>
10
- <div class="product-grid">
11
- <div v-for="p in products" :key="p.id" class="product-card">
12
- <div class="product-image">{{ p.image }}</div>
13
- <div class="product-info">
14
- <span class="product-category">{{ p.category }}</span>
15
- <h3>{{ p.name }}</h3>
16
- <p>{{ p.description }}</p>
17
- <div class="product-footer">
18
- <span class="product-price">${{ p.price.toFixed(2) }}</span>
19
- <button class="add-to-cart" @click="$emit('add-to-cart', p)">Add to Cart</button>
20
- </div>
21
- </div>
22
- </div>
23
- </div>
24
- </section>
25
- </template>
26
-
27
- <style scoped>
28
- .product-section h2 { font-size: 1.75rem; font-weight: 700; margin-bottom: 1.5rem; }
29
- .product-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); gap: 1.5rem; }
30
- .product-card { border: 1px solid #e5e7eb; border-radius: 12px; overflow: hidden; transition: all 0.2s; }
31
- .product-card:hover { box-shadow: 0 8px 25px rgba(0,0,0,0.08); transform: translateY(-2px); }
32
- .product-image { font-size: 4rem; text-align: center; padding: 2rem; background: #f9fafb; }
33
- .product-info { padding: 1.25rem; }
34
- .product-category { font-size: 0.75rem; color: #4f46e5; font-weight: 600; text-transform: uppercase; }
35
- .product-info h3 { font-size: 1.1rem; margin: 0.25rem 0; }
36
- .product-info p { color: #6b7280; font-size: 0.9rem; margin-bottom: 1rem; }
37
- .product-footer { display: flex; justify-content: space-between; align-items: center; }
38
- .product-price { font-size: 1.25rem; font-weight: 700; }
39
- .add-to-cart { background: #4f46e5; color: white; border: none; padding: 0.5rem 1rem; border-radius: 6px; cursor: pointer; font-weight: 500; }
40
- </style>
@@ -1,29 +0,0 @@
1
- export function ContactForm() {
2
- return (
3
- <section id="contact" className="contact-section">
4
- <h2>Get In Touch</h2>
5
- <p className="section-subtitle">Have a project in mind? Let's work together.</p>
6
- <form className="contact-form" onSubmit={(e) => e.preventDefault()}>
7
- <div className="form-row">
8
- <div className="form-group">
9
- <label htmlFor="name">Name</label>
10
- <input type="text" id="name" placeholder="Your name" />
11
- </div>
12
- <div className="form-group">
13
- <label htmlFor="email">Email</label>
14
- <input type="email" id="email" placeholder="your@email.com" />
15
- </div>
16
- </div>
17
- <div className="form-group">
18
- <label htmlFor="subject">Subject</label>
19
- <input type="text" id="subject" placeholder="Project inquiry" />
20
- </div>
21
- <div className="form-group">
22
- <label htmlFor="message">Message</label>
23
- <textarea id="message" rows={5} placeholder="Tell me about your project..." />
24
- </div>
25
- <button type="submit" className="btn btn-primary">Send Message</button>
26
- </form>
27
- </section>
28
- );
29
- }
@@ -1,24 +0,0 @@
1
- export function HeroSection() {
2
- return (
3
- <header className="portfolio-hero">
4
- <nav className="portfolio-nav">
5
- <div className="logo">{{projectName}}</div>
6
- <div className="nav-links">
7
- <a href="#projects">Projects</a>
8
- <a href="#skills">Skills</a>
9
- <a href="#contact">Contact</a>
10
- </div>
11
- </nav>
12
- <div className="hero-content">
13
- <span className="hero-greeting">Hi, I'm</span>
14
- <h1>Beknur</h1>
15
- <p className="hero-role">Frontend Developer & Software Engineer</p>
16
- <p className="hero-desc">I craft pixel-perfect, user-centric web experiences with modern technologies. Passionate about clean code and great design.</p>
17
- <div className="hero-actions">
18
- <a href="#projects" className="btn btn-primary">View My Work</a>
19
- <a href="#contact" className="btn btn-outline">Get In Touch</a>
20
- </div>
21
- </div>
22
- </header>
23
- );
24
- }
@@ -1,33 +0,0 @@
1
- const projects = [
2
- { title: 'E-commerce Platform', description: 'A full-featured online store with cart, checkout, and payment integration.', tags: ['React', 'Node.js', 'Stripe'], image: '🛒' },
3
- { title: 'Task Management App', description: 'Collaborative task management with real-time updates and team features.', tags: ['Vue.js', 'Firebase', 'Tailwind'], image: '📋' },
4
- { title: 'Weather Dashboard', description: 'Beautiful weather visualization with 5-day forecasts and location search.', tags: ['TypeScript', 'API', 'Chart.js'], image: '🌤️' },
5
- { title: 'Social Media App', description: 'Social networking platform with posts, comments, and real-time messaging.', tags: ['Next.js', 'PostgreSQL', 'WebSocket'], image: '💬' },
6
- { title: 'Portfolio Website', description: 'Responsive portfolio with animations and dark mode support.', tags: ['React', 'Framer Motion', 'SCSS'], image: '🎨' },
7
- { title: 'Blog CMS', description: 'Content management system with markdown editor and SEO optimization.', tags: ['Nuxt', 'MongoDB', 'Markdown'], image: '📝' },
8
- ];
9
-
10
- export function Projects() {
11
- return (
12
- <section id="projects" className="projects-section">
13
- <h2>Featured Projects</h2>
14
- <p className="section-subtitle">A selection of my recent work</p>
15
- <div className="projects-grid">
16
- {projects.map((project, i) => (
17
- <div key={i} className="project-card">
18
- <div className="project-image">{project.image}</div>
19
- <div className="project-info">
20
- <h3>{project.title}</h3>
21
- <p>{project.description}</p>
22
- <div className="project-tags">
23
- {project.tags.map((tag, j) => (
24
- <span key={j} className="tag">{tag}</span>
25
- ))}
26
- </div>
27
- </div>
28
- </div>
29
- ))}
30
- </div>
31
- </section>
32
- );
33
- }
@@ -1,27 +0,0 @@
1
- const skillGroups = [
2
- { category: 'Frontend', skills: ['React', 'Vue.js', 'Angular', 'TypeScript', 'Next.js', 'Nuxt'] },
3
- { category: 'Styling', skills: ['Tailwind CSS', 'SCSS', 'Material UI', 'Styled Components', 'CSS Modules'] },
4
- { category: 'Backend', skills: ['Node.js', 'Express', 'PostgreSQL', 'MongoDB', 'REST API', 'GraphQL'] },
5
- { category: 'Tools', skills: ['Git', 'Docker', 'Vite', 'Webpack', 'Figma', 'VS Code'] },
6
- ];
7
-
8
- export function Skills() {
9
- return (
10
- <section id="skills" className="skills-section">
11
- <h2>Skills & Technologies</h2>
12
- <p className="section-subtitle">Technologies I work with on a daily basis</p>
13
- <div className="skills-grid">
14
- {skillGroups.map((group, i) => (
15
- <div key={i} className="skill-group">
16
- <h3>{group.category}</h3>
17
- <div className="skill-tags">
18
- {group.skills.map((skill, j) => (
19
- <span key={j} className="skill-tag">{skill}</span>
20
- ))}
21
- </div>
22
- </div>
23
- ))}
24
- </div>
25
- </section>
26
- );
27
- }
@@ -1,5 +0,0 @@
1
- export default {
2
- plugins: {
3
- '@tailwindcss/postcss': {},
4
- },
5
- };
@@ -1,11 +0,0 @@
1
- /** @type {import('tailwindcss').Config} */
2
- export default {
3
- content: [
4
- './index.html',
5
- './src/**/*.{js,ts,jsx,tsx,vue}',
6
- ],
7
- theme: {
8
- extend: {},
9
- },
10
- plugins: [],
11
- };