# =============================== # Stage 1: Build Angular app # =============================== FROM node:18-alpine AS builder WORKDIR /app # Copy package files and install dependencies COPY package*.json ./ RUN npm ci --legacy-peer-deps # Copy source and build COPY . . RUN npm run build # =============================== # Stage 2: Serve with Nginx # =============================== FROM nginx:alpine # Install wget for healthcheck RUN apk add --no-cache wget # Copy built files COPY --from=builder /app/dist/fuse/browser /usr/share/nginx/html # Simple nginx config for Angular SPA RUN echo 'server { \n\ listen 80; \n\ root /usr/share/nginx/html; \n\ index index.html; \n\ location / { \n\ try_files $uri $uri/ /index.html; \n\ } \n\ }' > /etc/nginx/conf.d/default.conf EXPOSE 80 CMD ["nginx", "-g", "daemon off;"]