# syntax=docker/dockerfile:1.4 # Utiliser une image Node.js légère FROM node:20-alpine # Build arguments pour invalider le cache si nécessaire ARG BUILD_DATE=unknown ARG BUILD_VERSION=unknown ARG CACHE_BUST=1 LABEL build.date="${BUILD_DATE}" \ build.version="${BUILD_VERSION}" \ cache.bust="${CACHE_BUST}" # Invalider le cache en utilisant CACHE_BUST dans une instruction RUN # Cela force Docker à reconstruire à partir de cette ligne si CACHE_BUST change # Utiliser CACHE_BUST dans une variable d'environnement pour forcer l'invalidation RUN echo "Cache bust: ${CACHE_BUST}" && \ echo "Build date: ${BUILD_DATE}" && \ date && \ echo "${CACHE_BUST}" > /tmp/cache_bust.txt WORKDIR /app # Variables d'environnement à définir AVANT npm install ENV HUSKY=0 ENV HUSKY_SKIP_INSTALL=1 ENV NODE_PATH=/app/node_modules ENV NODE_ENV=production # Installation des dépendances système RUN apk add --no-cache git python3 # Copie des fichiers de dépendances racine COPY package.json package-lock.json* ./ # Installation des dépendances Node racine (pour scripts: generate-team-visualization-data, etc.) RUN npm install --legacy-peer-deps --ignore-scripts # Copie du reste du projet (inclut radar-app/) COPY . . RUN chmod +x scripts/start-business.sh # Installer les dépendances dans radar-app (Next.js et dépendances du framework) # Désactiver le script prepare (husky) pour éviter les erreurs RUN cd radar-app && \ node -e "const fs=require('fs');const p='package.json';const pkg=JSON.parse(fs.readFileSync(p,'utf8'));pkg.scripts=pkg.scripts||{};pkg.scripts.prepare='';fs.writeFileSync(p,JSON.stringify(pkg,null,2));" && \ npm install --legacy-peer-deps --include=dev cytoscape cytoscape-cose-bilkent echarts-for-react postcss && \ npm run build:icons # --- CONFIGURATION BUSINESS --- # Application de la logique Business (remplacement de la config et des données) # Préserver la structure de dossiers par date pour que le framework puisse parser les dates RUN cp radar-business/config-business.json config.json && \ rm -rf radar/* && \ mkdir -p radar/2025-01-15 && \ cp -r radar-business/2025-01-15/* radar/2025-01-15/ # Toujours régénérer les données de visualisation équipe (pour avoir les bons rings) RUN echo "🔄 Régénération des données de visualisation équipe..." && \ node scripts/generate-team-visualization-data.js && \ echo "✅ Données de visualisation équipe générées" && \ echo "🔍 Vérification contenu team-visualization-data.json:" && \ ls -la public/team-visualization-data.json && \ head -20 public/team-visualization-data.json # Copier les fichiers nécessaires dans radar-app avant le build RUN rm -rf radar-app/data/radar && \ mkdir -p radar-app/data/radar/2025-01-15 && \ cp -r radar-business/2025-01-15/* radar-app/data/radar/2025-01-15/ && \ # Supprimer toute release de démo (2017-03-01, 2024-03-01, etc.) éventuellement présentes find radar-app/data/radar -mindepth 1 -maxdepth 1 ! -name '2025-01-15' -exec rm -rf {} + && \ cp radar-business/config-business.json radar-app/data/config.json && \ rm -rf radar-app/public && mkdir -p radar-app/public && \ cp -r public/* radar-app/public/ && \ cp public/_team-content radar-app/public/_team-content 2>/dev/null || true && \ cp public/team-visualization-data.json radar-app/public/team-visualization-data.json 2>/dev/null || true && \ cp about.md radar-app/data/about.md 2>/dev/null || echo "about.md not found, skipping" && \ cp custom.css radar-app/src/styles/custom.css 2>/dev/null || echo "custom.css not found, skipping" && \ echo "Fichiers public copiés" && \ echo "📁 Vérification des fichiers team dans radar-app/public/:" && \ ls -la radar-app/public/ | grep -E "(team\.html|team-visualization)" && echo "✅ Fichiers team trouvés" || (echo "⚠️ Fichiers team non trouvés dans radar-app/public/" && echo "📁 Contenu de public/ source:" && ls -la public/ | head -10) && \ echo "📁 Vérification que _team-content existe dans public/ source:" && \ test -f public/_team-content && echo "✅ public/_team-content existe" || echo "❌ public/_team-content n'existe pas" # Diagnostic : compter les fichiers markdown copiés dans radar-app/data/radar RUN echo "📊 Comptage des fichiers .md dans radar-app/data/radar" && \ find radar-app/data/radar -name "*.md" | wc -l && \ find radar-app/data/radar -name "*.md" | head -10 # Créer la page Next.js /team ET un fichier HTML statique /team/index.html # La page Next.js pour le routing, le HTML statique pour garantir l'affichage RUN mkdir -p radar-app/src/pages COPY docker/team-page.tsx radar-app/src/pages/team.tsx # Modifier _document.tsx pour charger team-block-script.js en premier (avant le rendu) COPY docker/patch_document.py /tmp/patch_document.py RUN python3 /tmp/patch_document.py && \ echo "📄 _document.tsx apres modification:" && \ cat radar-app/src/pages/_document.tsx # Script Python pour ajouter le lien Équipe dans Navigation.tsx (supprime TOUS les doublons) COPY docker/add_team_link.py /tmp/add_team_link.py # Script shell pour gérer l'ajout du lien Équipe COPY docker/add_team_link.sh /tmp/add_team_link.sh RUN chmod +x /tmp/add_team_link.sh && \ echo "🔍 VÉRIFICATION: Scripts modifiés:" && \ echo "=== team-block-script.js ===" && \ head -10 public/team-block-script.js && \ echo "=== strategie-script.js ===" && \ grep -A 2 -B 1 "__blockTeamPages" public/strategie-script.js || echo "❌ Protection non trouvée" && \ echo "=== config-business.json ===" && \ grep "jsFile" radar-business/config-business.json # Exécuter le script RUN /tmp/add_team_link.sh # Builder l'application en mode production pour éviter Fast Refresh # Utiliser WORKDIR pour changer de répertoire de manière fiable WORKDIR /app/radar-app RUN npm run build:data RUN npm run build # S'assurer que _team-content.html et team-visualization-data.json sont copiés dans out/ # Next.js en mode export copie automatiquement les fichiers de public/, mais vérifions quand même RUN if [ -d "out" ]; then \ echo "📁 Contenu de out/ avant copie:" && \ ls -la out/ | head -10 && \ echo "" && \ echo "🔍 Recherche de _team-content..." && \ if [ -f "public/_team-content" ]; then \ cp -v public/_team-content out/_team-content && echo "✅ _team-content copié depuis public/ vers out/"; \ elif [ -f "/app/public/_team-content" ]; then \ cp -v /app/public/_team-content out/_team-content && echo "✅ _team-content copié depuis /app/public/ vers out/"; \ else \ echo "⚠️ _team-content introuvable dans public/ ou /app/public/"; \ echo "📁 Contenu de public/:" && \ ls -la public/ 2>/dev/null | head -10 || echo "public/ non accessible"; \ echo "📁 Contenu de /app/public/:" && \ ls -la /app/public/ 2>/dev/null | head -10 || echo "/app/public/ non accessible"; \ fi && \ if [ -f "public/team-visualization-data.json" ]; then \ cp -v public/team-visualization-data.json out/team-visualization-data.json && echo "✅ team-visualization-data.json copié dans out/"; \ else \ echo "⚠️ public/team-visualization-data.json introuvable"; \ fi && \ if [ -d "public/team" ]; then \ mkdir -p out/team && \ cp -rv public/team/* out/team/ && echo "✅ /team/index.html copié dans out/team/"; \ elif [ -d "/app/radar-app/public/team" ]; then \ mkdir -p out/team && \ cp -rv /app/radar-app/public/team/* out/team/ && echo "✅ /team/index.html copié depuis /app/radar-app/public/team/"; \ fi && \ echo "🔍 VÉRIFICATION: _team-content dans out/:" && \ ls -la out/_team-content 2>/dev/null || echo "❌ _team-content absent de out/" && \ echo "" && \ echo "📁 Vérification finale dans out/:" && \ ls -la out/ | grep -E "(team\.html|team-visualization)" && echo "✅ Fichiers team présents dans out/" || echo "⚠️ Fichiers team non trouvés dans out/"; \ else \ echo "❌ Dossier out/ introuvable après build"; \ ls -la . | head -20; \ fi && \ echo "" && \ echo "📋 Vérification finale de Navigation.tsx après build:" && \ grep -qE 'href="/team' src/components/Navigation/Navigation.tsx && echo "✅ Lien Équipe toujours présent dans Navigation.tsx après build" || echo "❌ Lien Équipe absent de Navigation.tsx après build" && \ echo "" && \ echo "🔍 Vérification des doublons dans le HTML généré..." && \ if [ -f "out/index.html" ]; then \ header_count=$(grep -oE ']*>' out/index.html | wc -l | tr -d ' '); \ nav_count=$(grep -oE ']*>' out/index.html | wc -l | tr -d ' '); \ logo_count=$(grep -oE 'logo\.svg|logoFile|CoeurBox' out/index.html | wc -l | tr -d ' '); \ echo "📊 HTML généré: $header_count header/nav, $nav_count nav, $logo_count logo"; \ if [ "$header_count" -gt "2" ] || [ "$nav_count" -gt "2" ]; then \ echo "❌ ERREUR: Duplication détectée dans le HTML généré!"; \ echo "📄 Recherche des headers/nav dans index.html:"; \ grep -nE '