@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.
- package/README.md +226 -212
- package/package.json +63 -63
- package/templates/extras/typescript/deps.json +6 -0
- package/templates/extras/typescript/react/tsconfig.json +21 -0
- package/templates/extras/typescript/vanilla/tsconfig.json +19 -0
- package/templates/extras/typescript/vue/tsconfig.json +20 -0
- package/templates/overlays/blog/angular/src/app/app.component.ts +100 -0
- package/templates/overlays/blog/angular/src/app/app.routes.ts +12 -0
- package/templates/overlays/blog/angular/src/app/components/blog-sidebar.component.ts +115 -0
- package/templates/overlays/blog/angular/src/app/components/post-card.component.ts +94 -0
- package/templates/overlays/blog/angular/src/app/pages/about.component.ts +114 -0
- package/templates/overlays/blog/angular/src/app/pages/category.component.ts +141 -0
- package/templates/overlays/blog/angular/src/app/pages/home.component.ts +143 -0
- package/templates/overlays/blog/angular/src/app/pages/post-detail.component.ts +196 -0
- package/templates/overlays/blog/angular/src/main.ts +10 -0
- package/templates/overlays/blog/nextjs/src/app/about/page.tsx +55 -0
- package/templates/overlays/blog/nextjs/src/app/category/[slug]/page.tsx +52 -0
- package/templates/overlays/blog/nextjs/src/app/components/BlogFooter.tsx +46 -0
- package/templates/overlays/blog/nextjs/src/app/components/BlogHeader.tsx +37 -0
- package/templates/overlays/blog/nextjs/src/app/components/BlogSidebar.tsx +56 -0
- package/templates/overlays/blog/nextjs/src/app/components/PostCard.tsx +42 -0
- package/templates/overlays/blog/nextjs/src/app/globals.css +158 -0
- package/templates/overlays/blog/nextjs/src/app/layout.tsx +20 -0
- package/templates/overlays/blog/nextjs/src/app/page.tsx +36 -0
- package/templates/overlays/blog/nextjs/src/app/post/[id]/page.tsx +78 -0
- package/templates/overlays/blog/nuxt/app.vue +27 -0
- package/templates/overlays/blog/nuxt/components/BlogFooter.vue +48 -0
- package/templates/overlays/blog/nuxt/components/BlogHeader.vue +55 -0
- package/templates/overlays/blog/nuxt/components/BlogSidebar.vue +144 -0
- package/templates/overlays/blog/nuxt/components/PostCard.vue +125 -0
- package/templates/overlays/blog/nuxt/layouts/default.vue +25 -0
- package/templates/overlays/blog/nuxt/pages/about.vue +161 -0
- package/templates/overlays/blog/nuxt/pages/category/[slug].vue +80 -0
- package/templates/overlays/blog/nuxt/pages/index.vue +54 -0
- package/templates/overlays/blog/nuxt/pages/post/[id].vue +158 -0
- package/templates/overlays/blog/react/src/App.css +58 -18
- package/templates/overlays/blog/react/src/App.tsx +16 -31
- package/templates/overlays/blog/react/src/components/BlogFooter.tsx +4 -2
- package/templates/overlays/blog/react/src/components/BlogHeader.tsx +12 -6
- package/templates/overlays/blog/react/src/components/BlogSidebar.tsx +9 -8
- package/templates/overlays/blog/react/src/components/Layout.tsx +17 -0
- package/templates/overlays/blog/react/src/components/PostCard.tsx +30 -0
- package/templates/overlays/blog/react/src/data/posts.ts +22 -0
- package/templates/overlays/blog/react/src/pages/About.tsx +33 -0
- package/templates/overlays/blog/react/src/pages/Category.tsx +29 -0
- package/templates/overlays/blog/react/src/pages/Home.tsx +18 -0
- package/templates/overlays/blog/react/src/pages/PostDetail.tsx +38 -0
- package/templates/overlays/blog/vanilla/src/main.ts +112 -0
- package/templates/overlays/blog/vanilla/src/pages/about.ts +106 -0
- package/templates/overlays/blog/vanilla/src/pages/category.ts +86 -0
- package/templates/overlays/blog/vanilla/src/pages/home.ts +103 -0
- package/templates/overlays/blog/vanilla/src/pages/post-detail.ts +108 -0
- package/templates/overlays/blog/vanilla/src/router.ts +33 -0
- package/templates/overlays/blog/vanilla/src/style.css +677 -0
- package/templates/overlays/blog/vue/src/App.vue +29 -0
- package/templates/overlays/blog/vue/src/components/BlogFooter.vue +8 -0
- package/templates/overlays/blog/vue/src/components/BlogHeader.vue +14 -0
- package/templates/overlays/blog/vue/src/components/BlogSidebar.vue +31 -0
- package/templates/overlays/blog/vue/src/components/PostCard.vue +17 -0
- package/templates/overlays/blog/vue/src/data.ts +82 -0
- package/templates/overlays/blog/vue/src/main.ts +6 -0
- package/templates/overlays/blog/vue/src/pages/About.vue +17 -0
- package/templates/overlays/blog/vue/src/pages/Category.vue +32 -0
- package/templates/overlays/blog/vue/src/pages/Home.vue +14 -0
- package/templates/overlays/blog/vue/src/pages/PostDetail.vue +22 -0
- package/templates/overlays/blog/vue/src/router.ts +19 -0
- package/templates/overlays/blog/vue/src/style.css +288 -0
- package/templates/overlays/crm/angular/src/app/app.component.ts +110 -0
- package/templates/overlays/crm/angular/src/app/app.routes.ts +12 -0
- package/templates/overlays/crm/angular/src/app/components/contacts-table.component.ts +98 -0
- package/templates/overlays/crm/angular/src/app/components/stats-cards.component.ts +63 -0
- package/templates/overlays/crm/angular/src/app/pages/contacts.component.ts +70 -0
- package/templates/overlays/crm/angular/src/app/pages/dashboard-home.component.ts +38 -0
- package/templates/overlays/crm/angular/src/app/pages/deals.component.ts +145 -0
- package/templates/overlays/crm/angular/src/app/pages/settings.component.ts +103 -0
- package/templates/overlays/crm/angular/src/main.ts +8 -0
- package/templates/overlays/crm/nextjs/src/app/components/ContactsTable.tsx +69 -0
- package/templates/overlays/crm/nextjs/src/app/components/Sidebar.tsx +45 -0
- package/templates/overlays/crm/nextjs/src/app/components/StatsCards.tsx +31 -0
- package/templates/overlays/crm/nextjs/src/app/contacts/page.tsx +111 -0
- package/templates/overlays/crm/nextjs/src/app/deals/page.tsx +111 -0
- package/templates/overlays/crm/nextjs/src/app/globals.css +165 -0
- package/templates/overlays/crm/nextjs/src/app/layout.tsx +20 -0
- package/templates/overlays/crm/nextjs/src/app/page.tsx +43 -0
- package/templates/overlays/crm/nextjs/src/app/settings/page.tsx +91 -0
- package/templates/overlays/crm/nuxt/app.vue +27 -0
- package/templates/overlays/crm/nuxt/components/ContactsTable.vue +140 -0
- package/templates/overlays/crm/nuxt/components/CrmSidebar.vue +97 -0
- package/templates/overlays/crm/nuxt/components/StatsCards.vue +63 -0
- package/templates/overlays/crm/nuxt/layouts/default.vue +21 -0
- package/templates/overlays/crm/nuxt/pages/contacts.vue +79 -0
- package/templates/overlays/crm/nuxt/pages/deals.vue +229 -0
- package/templates/overlays/crm/nuxt/pages/index.vue +186 -0
- package/templates/overlays/crm/nuxt/pages/settings.vue +233 -0
- package/templates/overlays/crm/react/src/App.css +49 -20
- package/templates/overlays/crm/react/src/App.tsx +16 -41
- package/templates/overlays/crm/react/src/components/ContactsTable.tsx +8 -8
- package/templates/overlays/crm/react/src/components/Layout.tsx +15 -0
- package/templates/overlays/crm/react/src/components/Sidebar.tsx +20 -14
- package/templates/overlays/crm/react/src/components/StatsCards.tsx +10 -12
- package/templates/overlays/crm/react/src/data/contacts.ts +19 -0
- package/templates/overlays/crm/react/src/pages/Contacts.tsx +32 -0
- package/templates/overlays/crm/react/src/pages/DashboardHome.tsx +44 -0
- package/templates/overlays/crm/react/src/pages/Deals.tsx +48 -0
- package/templates/overlays/crm/react/src/pages/Settings.tsx +35 -0
- package/templates/overlays/crm/vanilla/src/main.ts +95 -0
- package/templates/overlays/crm/vanilla/src/pages/contacts.ts +87 -0
- package/templates/overlays/crm/vanilla/src/pages/dashboard-home.ts +121 -0
- package/templates/overlays/crm/vanilla/src/pages/deals.ts +116 -0
- package/templates/overlays/crm/vanilla/src/pages/settings.ts +129 -0
- package/templates/overlays/crm/vanilla/src/router.ts +33 -0
- package/templates/overlays/crm/vanilla/src/style.css +766 -0
- package/templates/overlays/crm/vue/src/App.vue +25 -0
- package/templates/overlays/crm/vue/src/components/ContactsTable.vue +30 -0
- package/templates/overlays/crm/vue/src/components/CrmSidebar.vue +14 -0
- package/templates/overlays/crm/vue/src/components/StatsCards.vue +23 -0
- package/templates/overlays/crm/vue/src/data.ts +38 -0
- package/templates/overlays/crm/vue/src/main.ts +6 -0
- package/templates/overlays/crm/vue/src/pages/Contacts.vue +25 -0
- package/templates/overlays/crm/vue/src/pages/DashboardHome.vue +19 -0
- package/templates/overlays/crm/vue/src/pages/Deals.vue +34 -0
- package/templates/overlays/crm/vue/src/pages/Settings.vue +33 -0
- package/templates/overlays/crm/vue/src/router.ts +19 -0
- package/templates/overlays/crm/vue/src/style.css +272 -0
- package/templates/overlays/dashboard/angular/src/app/app.component.ts +135 -0
- package/templates/overlays/dashboard/angular/src/app/app.routes.ts +24 -0
- package/templates/overlays/dashboard/angular/src/app/components/chart-placeholder.component.ts +86 -0
- package/templates/overlays/dashboard/angular/src/app/components/data-table.component.ts +140 -0
- package/templates/overlays/dashboard/angular/src/app/components/kpi-cards.component.ts +120 -0
- package/templates/overlays/dashboard/angular/src/app/pages/analytics.component.ts +138 -0
- package/templates/overlays/dashboard/angular/src/app/pages/overview.component.ts +58 -0
- package/templates/overlays/dashboard/angular/src/app/pages/settings.component.ts +128 -0
- package/templates/overlays/dashboard/angular/src/app/pages/users.component.ts +153 -0
- package/templates/overlays/dashboard/angular/src/main.ts +10 -0
- package/templates/overlays/dashboard/nextjs/src/app/analytics/page.tsx +76 -0
- package/templates/overlays/dashboard/nextjs/src/app/components/ChartPlaceholder.tsx +58 -0
- package/templates/overlays/dashboard/nextjs/src/app/components/DataTable.tsx +60 -0
- package/templates/overlays/dashboard/nextjs/src/app/components/KPICards.tsx +31 -0
- package/templates/overlays/dashboard/nextjs/src/app/components/Sidebar.tsx +45 -0
- package/templates/overlays/dashboard/nextjs/src/app/globals.css +150 -0
- package/templates/overlays/dashboard/nextjs/src/app/layout.tsx +20 -0
- package/templates/overlays/dashboard/nextjs/src/app/page.tsx +20 -0
- package/templates/overlays/dashboard/nextjs/src/app/settings/page.tsx +118 -0
- package/templates/overlays/dashboard/nextjs/src/app/users/page.tsx +99 -0
- package/templates/overlays/dashboard/nuxt/app.vue +27 -0
- package/templates/overlays/dashboard/nuxt/components/ChartPlaceholder.vue +73 -0
- package/templates/overlays/dashboard/nuxt/components/DashSidebar.vue +97 -0
- package/templates/overlays/dashboard/nuxt/components/DataTable.vue +126 -0
- package/templates/overlays/dashboard/nuxt/components/KPICards.vue +76 -0
- package/templates/overlays/dashboard/nuxt/layouts/default.vue +21 -0
- package/templates/overlays/dashboard/nuxt/pages/analytics.vue +94 -0
- package/templates/overlays/dashboard/nuxt/pages/index.vue +49 -0
- package/templates/overlays/dashboard/nuxt/pages/settings.vue +239 -0
- package/templates/overlays/dashboard/nuxt/pages/users.vue +227 -0
- package/templates/overlays/dashboard/react/src/App.css +50 -24
- package/templates/overlays/dashboard/react/src/App.tsx +16 -22
- package/templates/overlays/dashboard/react/src/components/ChartPlaceholder.tsx +5 -2
- package/templates/overlays/dashboard/react/src/components/DataTable.tsx +9 -1
- package/templates/overlays/dashboard/react/src/components/KPICards.tsx +4 -4
- package/templates/overlays/dashboard/react/src/components/Layout.tsx +13 -0
- package/templates/overlays/dashboard/react/src/components/Sidebar.tsx +15 -10
- package/templates/overlays/dashboard/react/src/pages/Analytics.tsx +33 -0
- package/templates/overlays/dashboard/react/src/pages/Overview.tsx +23 -0
- package/templates/overlays/dashboard/react/src/pages/Settings.tsx +41 -0
- package/templates/overlays/dashboard/react/src/pages/Users.tsx +57 -0
- package/templates/overlays/dashboard/vanilla/src/main.ts +101 -0
- package/templates/overlays/dashboard/vanilla/src/pages/analytics.ts +99 -0
- package/templates/overlays/dashboard/vanilla/src/pages/overview.ts +60 -0
- package/templates/overlays/dashboard/vanilla/src/pages/settings.ts +118 -0
- package/templates/overlays/dashboard/vanilla/src/pages/users.ts +80 -0
- package/templates/overlays/dashboard/vanilla/src/router.ts +33 -0
- package/templates/overlays/dashboard/vanilla/src/style.css +654 -0
- package/templates/overlays/dashboard/vue/src/App.vue +12 -0
- package/templates/overlays/dashboard/vue/src/components/ChartPlaceholder.vue +34 -0
- package/templates/overlays/dashboard/vue/src/components/DashSidebar.vue +19 -0
- package/templates/overlays/dashboard/vue/src/components/DataTable.vue +34 -0
- package/templates/overlays/dashboard/vue/src/components/KPICards.vue +18 -0
- package/templates/overlays/dashboard/vue/src/main.ts +6 -0
- package/templates/overlays/dashboard/vue/src/pages/Analytics.vue +32 -0
- package/templates/overlays/dashboard/vue/src/pages/Overview.vue +17 -0
- package/templates/overlays/dashboard/vue/src/pages/Settings.vue +65 -0
- package/templates/overlays/dashboard/vue/src/pages/Users.vue +44 -0
- package/templates/overlays/dashboard/vue/src/router.ts +15 -0
- package/templates/overlays/dashboard/vue/src/style.css +447 -0
- package/templates/overlays/ecommerce/angular/src/app/app.component.ts +147 -0
- package/templates/overlays/ecommerce/angular/src/app/app.routes.ts +10 -0
- package/templates/overlays/ecommerce/angular/src/app/components/product-card.component.ts +94 -0
- package/templates/overlays/ecommerce/angular/src/app/data/products.ts +75 -0
- package/templates/overlays/ecommerce/angular/src/app/pages/cart.component.ts +169 -0
- package/templates/overlays/ecommerce/angular/src/app/pages/home.component.ts +96 -0
- package/templates/overlays/ecommerce/angular/src/app/pages/product-detail.component.ts +124 -0
- package/templates/overlays/ecommerce/angular/src/main.ts +10 -0
- package/templates/overlays/ecommerce/nextjs/src/app/cart/page.tsx +74 -0
- package/templates/overlays/ecommerce/nextjs/src/app/components/CartProvider.tsx +80 -0
- package/templates/overlays/ecommerce/nextjs/src/app/components/Footer.tsx +44 -0
- package/templates/overlays/ecommerce/nextjs/src/app/components/Header.tsx +27 -0
- package/templates/overlays/ecommerce/nextjs/src/app/components/ProductCard.tsx +23 -0
- package/templates/overlays/ecommerce/nextjs/src/app/globals.css +144 -0
- package/templates/overlays/ecommerce/nextjs/src/app/layout.tsx +23 -0
- package/templates/overlays/ecommerce/nextjs/src/app/page.tsx +73 -0
- package/templates/overlays/ecommerce/nextjs/src/app/product/[id]/page.tsx +63 -0
- package/templates/overlays/ecommerce/nuxt/app.vue +27 -0
- package/templates/overlays/ecommerce/nuxt/components/ProductCard.vue +77 -0
- package/templates/overlays/ecommerce/nuxt/components/StoreFooter.vue +47 -0
- package/templates/overlays/ecommerce/nuxt/components/StoreHeader.vue +91 -0
- package/templates/overlays/ecommerce/nuxt/layouts/default.vue +43 -0
- package/templates/overlays/ecommerce/nuxt/pages/cart.vue +268 -0
- package/templates/overlays/ecommerce/nuxt/pages/index.vue +154 -0
- package/templates/overlays/ecommerce/nuxt/pages/product/[id].vue +211 -0
- package/templates/overlays/ecommerce/react/src/App.css +71 -59
- package/templates/overlays/ecommerce/react/src/App.tsx +18 -44
- package/templates/overlays/ecommerce/react/src/components/Footer.tsx +2 -2
- package/templates/overlays/ecommerce/react/src/components/Header.tsx +15 -14
- package/templates/overlays/ecommerce/react/src/components/Layout.tsx +20 -0
- package/templates/overlays/ecommerce/react/src/components/ProductCard.tsx +28 -0
- package/templates/overlays/ecommerce/react/src/data/products.ts +23 -0
- package/templates/overlays/ecommerce/react/src/pages/Cart.tsx +51 -0
- package/templates/overlays/ecommerce/react/src/pages/Home.tsx +37 -0
- package/templates/overlays/ecommerce/react/src/pages/ProductDetail.tsx +38 -0
- package/templates/overlays/ecommerce/vanilla/src/main.ts +73 -0
- package/templates/overlays/ecommerce/vanilla/src/pages/cart.ts +73 -0
- package/templates/overlays/ecommerce/vanilla/src/pages/home.ts +71 -0
- package/templates/overlays/ecommerce/vanilla/src/pages/product-detail.ts +81 -0
- package/templates/overlays/ecommerce/vanilla/src/router.ts +33 -0
- package/templates/overlays/ecommerce/vanilla/src/style.css +522 -0
- package/templates/overlays/ecommerce/vue/src/App.vue +17 -32
- package/templates/overlays/ecommerce/vue/src/components/ProductCard.vue +25 -0
- package/templates/overlays/ecommerce/vue/src/components/StoreFooter.vue +6 -12
- package/templates/overlays/ecommerce/vue/src/components/StoreHeader.vue +5 -23
- package/templates/overlays/ecommerce/vue/src/data.ts +23 -0
- package/templates/overlays/ecommerce/vue/src/main.ts +6 -0
- package/templates/overlays/ecommerce/vue/src/pages/Cart.vue +34 -0
- package/templates/overlays/ecommerce/vue/src/pages/Home.vue +27 -0
- package/templates/overlays/ecommerce/vue/src/pages/ProductDetail.vue +27 -0
- package/templates/overlays/ecommerce/vue/src/router.ts +13 -0
- package/templates/overlays/ecommerce/vue/src/style.css +359 -0
- package/templates/overlays/portfolio/angular/src/app/app.component.ts +102 -0
- package/templates/overlays/portfolio/angular/src/app/app.routes.ts +12 -0
- package/templates/overlays/portfolio/angular/src/app/components/project-card.component.ts +86 -0
- package/templates/overlays/portfolio/angular/src/app/components/skills-grid.component.ts +88 -0
- package/templates/overlays/portfolio/angular/src/app/pages/about.component.ts +122 -0
- package/templates/overlays/portfolio/angular/src/app/pages/contact.component.ts +131 -0
- package/templates/overlays/portfolio/angular/src/app/pages/home.component.ts +207 -0
- package/templates/overlays/portfolio/angular/src/app/pages/projects.component.ts +150 -0
- package/templates/overlays/portfolio/angular/src/main.ts +10 -0
- package/templates/overlays/portfolio/nextjs/src/app/about/page.tsx +70 -0
- package/templates/overlays/portfolio/nextjs/src/app/components/Footer.tsx +37 -0
- package/templates/overlays/portfolio/nextjs/src/app/components/Navbar.tsx +37 -0
- package/templates/overlays/portfolio/nextjs/src/app/components/ProjectCard.tsx +35 -0
- package/templates/overlays/portfolio/nextjs/src/app/components/SkillsGrid.tsx +45 -0
- package/templates/overlays/portfolio/nextjs/src/app/contact/page.tsx +138 -0
- package/templates/overlays/portfolio/nextjs/src/app/globals.css +197 -0
- package/templates/overlays/portfolio/nextjs/src/app/layout.tsx +20 -0
- package/templates/overlays/portfolio/nextjs/src/app/page.tsx +60 -0
- package/templates/overlays/portfolio/nextjs/src/app/projects/page.tsx +56 -0
- package/templates/overlays/portfolio/nuxt/app.vue +27 -0
- package/templates/overlays/portfolio/nuxt/components/PortfolioFooter.vue +49 -0
- package/templates/overlays/portfolio/nuxt/components/PortfolioNav.vue +77 -0
- package/templates/overlays/portfolio/nuxt/components/ProjectCard.vue +102 -0
- package/templates/overlays/portfolio/nuxt/components/SkillsGrid.vue +89 -0
- package/templates/overlays/portfolio/nuxt/layouts/default.vue +21 -0
- package/templates/overlays/portfolio/nuxt/pages/about.vue +179 -0
- package/templates/overlays/portfolio/nuxt/pages/contact.vue +278 -0
- package/templates/overlays/portfolio/nuxt/pages/index.vue +160 -0
- package/templates/overlays/portfolio/nuxt/pages/projects.vue +116 -0
- package/templates/overlays/portfolio/react/src/App.css +54 -27
- package/templates/overlays/portfolio/react/src/App.tsx +16 -12
- package/templates/overlays/portfolio/react/src/components/Layout.tsx +17 -0
- package/templates/overlays/portfolio/react/src/components/Navbar.tsx +30 -0
- package/templates/overlays/portfolio/react/src/components/PortfolioFooter.tsx +5 -3
- package/templates/overlays/portfolio/react/src/components/ProjectCard.tsx +24 -0
- package/templates/overlays/portfolio/react/src/components/SkillsGrid.tsx +20 -0
- package/templates/overlays/portfolio/react/src/data/projects.ts +25 -0
- package/templates/overlays/portfolio/react/src/pages/About.tsx +43 -0
- package/templates/overlays/portfolio/react/src/pages/Contact.tsx +48 -0
- package/templates/overlays/portfolio/react/src/pages/Home.tsx +44 -0
- package/templates/overlays/portfolio/react/src/pages/Projects.tsx +36 -0
- package/templates/overlays/portfolio/vanilla/src/main.ts +58 -0
- package/templates/overlays/portfolio/vanilla/src/pages/about.ts +146 -0
- package/templates/overlays/portfolio/vanilla/src/pages/contact.ts +159 -0
- package/templates/overlays/portfolio/vanilla/src/pages/home.ts +123 -0
- package/templates/overlays/portfolio/vanilla/src/pages/projects.ts +89 -0
- package/templates/overlays/portfolio/vanilla/src/router.ts +33 -0
- package/templates/overlays/portfolio/vanilla/src/style.css +909 -0
- package/templates/overlays/portfolio/vue/src/App.vue +25 -0
- package/templates/overlays/portfolio/vue/src/components/PortfolioFooter.vue +14 -0
- package/templates/overlays/portfolio/vue/src/components/PortfolioNav.vue +16 -0
- package/templates/overlays/portfolio/vue/src/components/ProjectCard.vue +18 -0
- package/templates/overlays/portfolio/vue/src/components/SkillsGrid.vue +14 -0
- package/templates/overlays/portfolio/vue/src/data.ts +78 -0
- package/templates/overlays/portfolio/vue/src/main.ts +6 -0
- package/templates/overlays/portfolio/vue/src/pages/About.vue +30 -0
- package/templates/overlays/portfolio/vue/src/pages/Contact.vue +47 -0
- package/templates/overlays/portfolio/vue/src/pages/Home.vue +27 -0
- package/templates/overlays/portfolio/vue/src/pages/Projects.vue +33 -0
- package/templates/overlays/portfolio/vue/src/router.ts +19 -0
- package/templates/overlays/portfolio/vue/src/style.css +404 -0
- package/templates/react/package.json +23 -19
- package/templates/react/tsconfig.json +20 -0
- package/templates/styling/tailwind/deps.json +7 -6
- package/templates/styling/tailwind/nextjs/postcss.config.mjs +7 -0
- package/templates/styling/tailwind/nextjs/src/app/globals.css +1 -0
- package/templates/styling/tailwind/react/src/index.css +1 -0
- package/templates/styling/tailwind/react/vite.config.ts +7 -0
- package/templates/styling/tailwind/vanilla/src/style.css +1 -0
- package/templates/styling/tailwind/vanilla/vite.config.ts +6 -0
- package/templates/styling/tailwind/vue/src/style.css +1 -0
- package/templates/styling/tailwind/vue/vite.config.ts +7 -0
- package/templates/vanilla/package.json +15 -14
- package/templates/vanilla/tsconfig.json +19 -0
- package/templates/vue/package.json +21 -18
- package/templates/vue/tsconfig.json +20 -0
- package/templates/overlays/blog/react/src/components/PostList.tsx +0 -27
- package/templates/overlays/crm/react/src/components/Filters.tsx +0 -22
- package/templates/overlays/ecommerce/react/src/components/Cart.tsx +0 -47
- package/templates/overlays/ecommerce/react/src/components/ProductGrid.tsx +0 -32
- package/templates/overlays/ecommerce/vue/src/components/CartPanel.vue +0 -46
- package/templates/overlays/ecommerce/vue/src/components/ProductGrid.vue +0 -40
- package/templates/overlays/portfolio/react/src/components/ContactForm.tsx +0 -29
- package/templates/overlays/portfolio/react/src/components/HeroSection.tsx +0 -24
- package/templates/overlays/portfolio/react/src/components/Projects.tsx +0 -33
- package/templates/overlays/portfolio/react/src/components/Skills.tsx +0 -27
- package/templates/styling/tailwind/config/postcss.config.js +0 -5
- 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
|
-
}
|