GearGo, modern teknolojiler kullanılarak geliştirilen, Türkiye'nin en kapsamlı ve kullanıcı dostu araç kiralama web platformudur. React TypeScript, Material-UI ve güçlü animasyon kütüphaneleri ile geliştirilmiş, gelişmiş özellikler sunan profesyonel bir uygulamadır.
- Material-UI v5 ile profesyonel tasarım
- Styled Components ile özel stil tanımlamaları
- Emotion ile dinamik CSS-in-JS çözümleri
- Framer Motion ile sinematik animasyonlar
- React Spring ile fizik tabanlı animasyonlar
- Kapsamlı araç filtreleme sistemi
- Kategori, fiyat, özellik bazlı arama
- Interaktif araç galerisi
- Gerçek zamanlı stok kontrolü
- Favoriler sistemi
- Canlı kart önizlemesi - Girilen bilgiler anında kart üzerinde görünür
- Akıllı formatlar - Kart numarası otomatik boşluklar, MM/YY tarihi
- Güvenli ödeme - 256-bit SSL şifreleme
- Çoklu ödeme yöntemi - Kredi kartı, banka kartı, taksitli ödeme
- CVV güvenliği - Şifrelenmiş güvenlik kodu girişi
- Mobile-first yaklaşım
- Tüm ekran boyutlarında mükemmel görünüm
- Touch-friendly interface
- Progressive enhancement
- 5 adımlı rezervasyon süreci
- Adım göstergesi (Stepper) ile görsel ilerleme
- Gerçek zamanlı fiyat hesaplama
- Form validasyonu ve hata yönetimi
- Rezervasyon özeti ve onay sistemi
- Node.js 18+
- npm 9+ veya yarn 1.22+
-
Projeyi klonlayın:
git clone https://github.com/ThecoderPinar/geargo.git cd geargo -
Bağımlılıkları yükleyin:
npm install # veya yarn install -
Geliştirme sunucusunu başlatın:
npm run dev # veya yarn dev -
Tarayıcıda açın:
http://localhost:5173
npm run dev # Geliştirme sunucusu (http://localhost:5173)
npm run build # Production build
npm run preview # Build önizlemesi
npm run lint # ESLint kod kontrol
npm run type-check # TypeScript kontrolsrc/
├── components/ # Yeniden kullanılabilir bileşenler
│ ├── Header.tsx # Ana navigasyon menüsü
│ └── Footer.tsx # Alt bilgi ve linkler
├── pages/ # Ana sayfa bileşenleri
│ ├── HomePage.tsx # Ana sayfa - Hero, özellikler, araç galerisi
│ ├── CarsPage.tsx # Araç listesi ve filtreleme
│ ├── BookingPage.tsx # 5 adımlı rezervasyon sistemi
│ ├── ServicesPage.tsx # Hizmet paketleri ve özellikler
│ ├── BlogPage.tsx # Blog yazıları ve haberler
│ ├── AboutPage.tsx # Hakkımızda sayfası
│ └── ContactPage.tsx # İletişim bilgileri ve form
├── styles/
│ └── index.css # Global CSS ve tema değişkenleri
├── App.tsx # Ana uygulama ve routing
└── main.tsx # React uygulaması giriş noktası
:root {
--primary-color: #2563eb; /* Ana mavi */
--primary-dark: #1d4ed8; /* Koyu mavi */
--primary-light: #3b82f6; /* Açık mavi */
--secondary-color: #f59e0b; /* Turuncu */
--accent-color: #10b981; /* Yeşil */
--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}- Primary Font: Inter, Roboto, Helvetica, Arial
- Display Font: Poppins, Inter
- Responsive tipografi - Her ekran boyutu için optimize edilmiş
- 8px grid sistemi - Tutarlı boşluklar
- Flexbox ve CSS Grid - Modern layout teknikler
- Container queries - Bileşen bazlı responsive tasarım
- Hero Section: Gradient arka plan, animasyonlu istatistikler
- Özellikler: Servis avantajları ve özellikler
- Araç Galerisi: Popüler araçların preview'ı
- Call-to-Action: Rezervasyon yönlendirme butonları
- Gelişmiş filtreleme: Kategori, fiyat, özellikler
- Arama sistemi: Gerçek zamanlı araç arama
- Grid layout: Responsive araç kartları
- Sıralama: Fiyat, popülerlik, yeni eklenenler
- Tarih ve Konum: Alış-teslim tarihi ve lokasyon
- Araç Seçimi: Araç kategori ve model seçimi
- Kişisel Bilgiler: Müşteri bilgileri ve ehliyet
- Ödeme: Gelişmiş kart ödeme sistemi
- Onay: Rezervasyon özeti ve tamamlama
- Servis paketleri: Premium, ekonomik, kurumsal, şoförlü
- Özellik karşılaştırması: Paket içeriklerinin detayları
- Fiyatlandırma: Şeffaf fiyat bilgileri
- Makale listesi: Kategori bazlı blog yazıları
- Öne çıkan yazı: Hero blog post
- Filtreleme: Kategori bazlı filtreleme
- Yazar bilgileri: Avatar, yayın tarihi, okuma süresi
-
Yeni Bileşen Oluşturma:
// src/components/YeniBileşen.tsx import React from 'react' import { Box, Typography } from '@mui/material' import styled from '@emotion/styled' import { motion } from 'framer-motion' const StyledContainer = styled(Box)` // Styled components tanımlamaları ` const YeniBileşen: React.FC = () => { return ( <motion.div initial={{ opacity: 0 }} animate={{ opacity: 1 }} transition={{ duration: 0.5 }} > <StyledContainer> <Typography variant="h4">Yeni Bileşen</Typography> </StyledContainer> </motion.div> ) } export default YeniBileşen
-
Yeni Sayfa Ekleme:
src/pages/klasörüne yeni dosya ekleyinApp.tsxdosyasında route tanımlaması yapınHeader.tsxdosyasında menü linkini ekleyin
-
Stil Düzenlemeleri:
- Global stiller için
src/index.csskullanın - Bileşen özel stilleri için Styled Components kullanın
- Tema değişkenleri için CSS custom properties kullanın
- Global stiller için
- TypeScript: Tüm bileşenler tip güvenli olmalı
- ESLint: Kod kalite kurallarına uygun yazım
- Prettier: Otomatik kod formatlama
- Responsive: Mobil-first yaklaşım
npm run build- Tree shaking: Kullanılmayan kod elimination
- Code splitting: Sayfa bazlı kod ayrımı
- Bundle analysis: Bundle boyut optimizasyonu
- Image optimization: Otomatik resim sıkıştırma
- Vercel: One-click deployment
- Netlify: JAMstack hosting
- GitHub Pages: Static site hosting
- AWS S3 + CloudFront: Enterprise hosting
- Fork edin ve clone yapın
- Feature branch oluşturun:
git checkout -b feature/yeni-ozellik - Değişiklikleri commit edin:
git commit -m 'feat: yeni özellik eklendi' - Branch'i push edin:
git push origin feature/yeni-ozellik - Pull Request oluşturun
feat: yeni özellik ekleme
fix: hata düzeltme
docs: dokümantasyon güncellemesi
style: kod formatı değişikliği
refactor: kod refactoring
test: test ekleme/düzeltme
chore: build süreci veya araç güncellemesi
- ⚡ First Contentful Paint (FCP): < 1.5s
- 🎯 Largest Contentful Paint (LCP): < 2.5s
- 📱 Cumulative Layout Shift (CLS): < 0.1
- 🔄 First Input Delay (FID): < 100ms
npm run build-analyze # Bundle boyut analizi
npm run lighthouse # Performance audit- XSS Protection: Input sanitization
- CSRF Protection: Token-based authentication
- SSL/TLS: HTTPS zorunlu
- Data Validation: Client ve server-side validation
- Dependency Scanning: Güvenlik açığı taraması
| Browser | Version |
|---|---|
| Chrome | 90+ |
| Firefox | 88+ |
| Safari | 14+ |
| Edge | 90+ |
Bu proje MIT Lisansı altında lisanslanmıştır. Detaylar için LICENSE dosyasına bakınız.
- 👨💻 Geliştirici: Pınar Topuz
- 📧 Email: piinartp@gmail.com
- 🐙 GitHub: https://github.com/ThecoderPinar
- � LinkedIn: Pınar Topuz
- 📚 Dokümantasyon: docs.geargo.com
- 🐛 Bug Reports: GitHub Issues
- 💡 Feature Requests: GitHub Discussions
- ❓ Sorular: piinartp@gmail.com adresinden iletişime geçebilirsiniz
🚗 GearGo - Türkiye'nin En Gelişmiş Araç Kiralama Platformu ✨
Hayalinizdeki araç bir tık uzağınızda.
Geliştirici: Pınar Topuz | Email: piinartp@gmail.com
