# Stage 1: Build the React application
FROM node:22-alpine AS builder

WORKDIR /app

# Copy package.json and lockfile
COPY package*.json ./

# Install dependencies
RUN npm install

# Copy the rest of your application code
COPY . .

# Build the Vite application (this creates the /app/dist folder inside the container)
RUN npm run build

# Stage 2: Serve the application with Nginx
FROM nginx:alpine

# Set the default Hasura admin secret (can be overridden at runtime)
ENV HASURA_ADMIN_SECRET="nearle-admin-secret"

# Move to Nginx's public folder
WORKDIR /usr/share/nginx/html

# CRUCIAL: Remove Nginx's default "Welcome" page files completely
RUN rm -rf ./*

# Copy the compiled static assets FROM THE BUILDER STAGE
COPY --from=builder /app/dist/ .

# Copy your custom Nginx configuration into the conf.d directory so it gets included properly
COPY nginx.conf /etc/nginx/conf.d/default.conf

EXPOSE 80

CMD ["nginx", "-g", "daemon off;"]
