- Introduktion
- Teknisk Stack
- Installation
- Funktionalitet
- Deployment
- Miljövariabler
- Bidra till Projektet
Antiq är en modern fullstack-applikation som låter användare skapa, hantera och interagera med Antikvitetssannonser. Plattformen riktar sig till både privatpersoner och experter inom branschen, med särskilda funktioner för varje användargrupp.
- Användarhantering med säker autentisering
- Publicering och hantering av bostadsannonser
- Möjlighet att följa intressanta annonser
- Specialfunktioner för expertanvändare (offerthantering)
- Administrativt gränssnitt för innehåll och användarmoderering
- React med TypeScript för typsäker utveckling
- Tailwind CSS för responsiv design och styling
- Express.js som server-ramverk
- MongoDB Atlas för databashantering
- JWT (JSON Web Tokens) för säker autentisering
- Cloudinary för bildhantering och -lagring
- Netlify för frontend-hosting
- Render för backend-hosting
- Bcrypt för hashade lösenord
- React-hot-toast för snygga notifikationer.
- React-confirm-alert för snyggare windows:alert().
- Node.js (version 14 eller senare)
- npm (Node Package Manager)
- Git
- Konton på MongoDB Atlas och Cloudinary
-
Klona Repositoryt
git clone https://github.com/chas-academy/u09-fullstack-js-HarveyBong.git cd u09-Fullstack
-
Backend Setup
cd backend npm install
Skapa en
.env
-fil i backend-mappen med följande innehåll:MONGO_URL=din-mongodb-url JWT_SECRET=din-jwt-secret CLOUDINARY_URL=din-cloudinary-url CLOUDINARY_API_KEY=din-cloudinary-api-nyckel CLOUDINARY_API_SECRET=din-cloudinary-api-secret
-
Frontend Setup
cd ../frontend npm install
-
Starta Utvecklingsservrarna
Backend:
cd backend npm start
Frontend:
cd frontend npm run dev
-
Autentisering
- Registrering av nytt konto
- Inloggning med e-post och lösenord
- Säker sessionshantering med JWT
-
Annonshantering
- Skapa nya annonser
- Laddar upp bild kopplat till annonsen
- Visa lista över Skapade annonser
- Ta bort egna annonser
-
Interaktiva Funktioner
- Följ intressanta annonser
- Visa lista över följda annonser
- Skicka offerter (endast tillgängligt för expertanvändare)
-
Användarhantering
- Visa lista över alla användare
- Ta bort användarkonton vid behov
-
Annonsmoderering
-
Granska alla publicerade annonser
-
Ta bort olämpligt innehåll
-
Ta bort Användare
-
-
Förbered Frontend-bygget
cd frontend npm run build
-
Konfigurera Netlify
- Skapa ett nytt projekt på Netlify
- Välj "Deploy manually"
- Dra och släpp
build
-mappen till Netlify's deploymentyta
Alternativt, för kontinuerlig deployment:
- Koppla ditt GitHub-repo till Netlify
- Sätt byggkommandot till
npm run build
- Ange
build
som publiceringskatalog
-
Förbered Backend
- Skapa ett konto på Render
- Välj "New Web Service"
- Koppla till ditt GitHub-repo
-
Konfigurera Render
- Välj huvudbranch för deployment
- Sätt byggkommandot till
npm install
- Sätt startkommandot till
npm start
-
Konfigurera Miljövariabler
- Gå till "Environment" i Render dashboard
- Lägg till alla variabler från din
.env
-fil
Backend kräver följande miljövariabler i .env
-filen:
# Databas
MONGO_URL=din-mongodb-url
# Autentisering
JWT_SECRET=din-jwt-secret
# Cloudinary Konfiguration
CLOUDINARY_URL=din-cloudinary-url
CLOUDINARY_API_KEY=din-cloudinary-api-nyckel
CLOUDINARY_API_SECRET=din-cloudinary-api-hemlighet
Alla dessa variabler måste vara korrekt konfigurerade för att applikationen ska fungera.