# Frontend Dockerfile - React/Vite NN3D Visualizer FROM node:20-alpine AS builder # Set working directory WORKDIR /app # Copy package files COPY package.json package-lock.json ./ # Install dependencies RUN npm ci # Copy source code COPY . . # Set environment variable for API URL (nginx proxy) ENV VITE_API_URL=/api # Build the application RUN npm run build # Production stage - serve with nginx FROM nginx:alpine # Copy custom nginx config COPY nginx.conf /etc/nginx/conf.d/default.conf # Copy built assets from builder COPY --from=builder /app/dist /usr/share/nginx/html # Expose port EXPOSE 80 # Health check HEALTHCHECK --interval=30s --timeout=10s --start-period=5s --retries=3 \ CMD wget --no-verbose --tries=1 --spider http://localhost:80/ || exit 1 # Start nginx CMD ["nginx", "-g", "daemon off;"]