Commit Graph

781 Commits

Author SHA1 Message Date
syoul
7c4204c689 ci: correction syntaxe Woodpecker (.woodpecker.yml)
- Suppression des headers Drone CI (kind/type/name)
- Déplacement du trigger when: au niveau global
- Volumes inline (host:container) au lieu des named volumes
- Suppression de la section volumes: Drone en bas de fichier
- Correction $$ → $ pour les variables dans les commandes
- Chaînage des cd avec && pour les commandes radar-app
- Image docker:27-cli cohérente avec le modèle de référence

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-19 18:03:33 +01:00
syoul
27685ee250 docs: mise à jour du README et ajout de la configuration CI Woodpecker
- Réécriture complète du README pour le projet stand-alone Techradar Laplank
- Ajout de .woodpecker.yml pour la pipeline CI/CD
- Mise à jour du .gitignore pour exclure les dossiers docs/

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-03-19 17:34:12 +01:00
syoul
236b8fe037 refactor: renommer le package de 'aoe-techradar' à 'techradar-laplank'
- Mise à jour du nom dans package.json
- Mise à jour du nom dans package-lock.json
- Le nom reflète mieux l'identité du projet Laplank

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-25 18:52:59 +01:00
syoul
e9fd40f27d fix: résolution des marqueurs de conflit dans radar-app/package.json
- Conservation de Next.js 16.1.6 et eslint-config-next 16.1.6

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-25 18:37:40 +01:00
syoul
6c304d461c merge: synchroniser stand-alone avec main (refactorisation stand-alone + migration Next.js 16)
- Merge de main dans stand-alone
- Résolution du conflit dans radar-app/package.json (conservation de Next.js 16.1.6)
- Intégration de la refactorisation stand-alone complète
- Migration Next.js 15.2.4 -> 16.1.6

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-25 18:36:03 +01:00
syoul
acb475d5d0 feat: migration Next.js 15.2.4 -> 16.1.6
- Mise à jour de Next.js vers 16.1.6 (dernière version stable)
- Mise à jour de eslint-config-next vers 16.1.6
- Ajout documentation migration-nextjs-16.md

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-25 18:35:55 +01:00
syoul
9d8ae3d32a refactor: projet stand-alone sans dépendance aoe_technology_radar
- Intégration du code source du framework dans radar-app/ (vendoring)
- Suppression de la dépendance npm aoe_technology_radar
- Création de scripts build-radar.js et serve-radar.js pour remplacer le CLI techradar
- Adaptation de tous les scripts et Docker pour utiliser radar-app/ au lieu de .techradar
- Refactorisation complète de Dockerfile.business
- Mise à jour de la documentation (architecture, déploiement, développement)
- Mise à jour de .gitignore pour ignorer les artefacts de build de radar-app/
- Ajout de postcss dans les dépendances Docker pour le build Next.js

Le projet est maintenant complètement indépendant du package externe.

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-25 18:11:40 +01:00
syoul
cc8df1a4af Doc: roadmap basee sur l'analyse du code source 2025-12-10 11:48:15 +01:00
syoul
b69850a23b Doc: plan d'implementation NetlifyCMS + Gitea pour edition des profils 2025-12-09 20:06:47 +01:00
syoul
b8ec3f2828 Ajout carte de profil cliquable pour les membres (graphe, matrice, equipe) 2025-12-09 19:45:00 +01:00
syoul
cdd6e1c573 Fix: detection navigation SPA pour page team 2025-12-09 19:26:54 +01:00
syoul
89c24b9cd8 Mise a jour du graphe reseau equipe et ajout page team 2025-12-09 19:20:13 +01:00
syoul
5c47f1f7c6 feat: Ajout Syoul aux blips Docker, Linux, ProxMox
- Docker: 1000i100, syoul (2 personnes)
- Linux: aya, boris, syoul (3 personnes)
- ProxMox: poka, syoul (2 personnes)
- Equipe genese passe de 2 a 4 membres
- Donnees regenerees
2025-12-09 18:30:32 +01:00
syoul
bc2cfdb1c3 feat: Mise a jour profil Syoul
- Nouveau role: Etudiant IPSSI - Alternance Admin Infrastructure Securisee chez AJR
- Competences: Proxmox, Docker, Linux, autohebergement
- Projets: Autohebergement personnel, Alternance AJR
- Donnees team-visualization-data.json regenerees
2025-12-09 18:11:27 +01:00
syoul
5d7d158436 docs: Mise a jour finale docs/app
- README.md: Structure fichiers mise a jour
- configuration.md: Ajout section script page equipe
- troubleshooting.md: Mise a jour diagnostic page equipe
2025-12-09 17:53:22 +01:00
syoul
240988ed61 docs: Mise a jour documentation page equipe
- guide-page-equipe.md: Architecture basee sur team-block-script.js
- architecture.md: Mise a jour structure et fonctionnement
- deploiement.md: Scripts Python pour Navigation et _document
- team-block-script.js: Utilise layout cose integre (pas cose-bilkent)
2025-12-09 17:50:23 +01:00
syoul
3553f1d839 fix: Script team-block-script.js avec remplacement DOM
- Nouvelle approche: remplace le DOM apres chargement (defer-compatible)
- Charge Cytoscape, ECharts dynamiquement
- Initialise les 3 visualisations: graphe reseau, matrice congestion, equipe genese
- Ajout de patch_document.py pour inclure le script dans _document.tsx
2025-12-09 17:03:20 +01:00
syoul
d326f24f8d fix: Retirer --single du serveur serve pour pages statiques Next.js
- Le flag --single redirigeait toutes les routes vers index.html
- Maintenant /team/ est correctement servi via /team/index.html
- Le script team-block-script.js sera chargé côté client
2025-12-09 16:47:32 +01:00
syoul
a5a71bcd8b fix: HTML complet intégré dans team-block-script.js
- Plus de dépendance aux fichiers externes HTML
- Utilise sessionStorage pour éviter les boucles
- document.write() pour remplacer complètement la page
2025-12-09 16:27:50 +01:00
syoul
16a346e8fe fix: supprimer meta refresh de team.tsx qui causait la boucle
La page team.tsx avait un meta refresh vers /team.html
Le reverse proxy redirige /team.html vers /team = boucle infinie

Solution: team.tsx retourne null, le contenu est géré par
team-block-script.js via iframe avec data URL
2025-12-09 16:15:27 +01:00
syoul
59acaf46cb fix: utiliser iframe avec data URL au lieu de document.write
document.write() après chargement cause un rechargement de page.
Solution: créer un iframe plein écran avec data:text/html;base64
L'iframe est un contexte isolé, pas de boucle possible.
2025-12-09 16:10:10 +01:00
syoul
c69b917f94 fix: intégrer le HTML en base64 dans le script (pas de requête HTTP)
Le reverse proxy intercepte toutes les requêtes.
Solution: encoder le HTML en base64 et le décoder avec atob()
Plus aucune requête HTTP pour le contenu de la page équipe.
2025-12-09 16:07:07 +01:00
syoul
484f0313b2 fix: renommer fichier sans extension pour éviter redirection reverse proxy
Le reverse proxy redirige tout *.html vers le chemin sans extension.
Solution: utiliser _team-content (sans .html)
2025-12-09 16:01:56 +01:00
syoul
c38ea72928 fix: renommer team.html en _team-content.html
Le reverse proxy redirige aussi les fetch vers /team.html.
Nouveau nom avec underscore pour éviter la règle de redirection.
2025-12-09 15:56:15 +01:00
syoul
95ab0b68ae fix: charger team.html via fetch au lieu de redirection
Le reverse proxy redirige /team.html vers /team, créant une boucle.
Solution: fetch le contenu de team.html et l'injecter dans le DOM
avec document.write() pour remplacer complètement la page.
2025-12-09 15:50:33 +01:00
syoul
e29b7401d6 fix: ajouter .techradar et build au .dockerignore
Les anciens fichiers dans .techradar/ local étaient copiés
dans le conteneur Docker, écrasant les nouveaux fichiers.
Cela causait le bug où team-block-script.js restait ancien.
2025-12-09 15:38:59 +01:00
syoul
45fc4c56d9 fix: team-block-script.js redirige directement vers team.html
- Supprime la logique de blocage complexe
- Redirige simplement /team vers /team.html
- Ne bloque plus si on est déjà sur team.html
2025-12-09 15:26:44 +01:00
syoul
be86854c7e fix: toujours régénérer les données équipe au build
- Ne plus vérifier si le fichier existe (les rings pourraient être obsolètes)
- Régénérer systématiquement avec les bons rings adopt/trial/assess/hold
- Mise à jour des données de visualisation avec les nouveaux rings
2025-12-09 15:22:19 +01:00
syoul
7b236f6770 fix: redirection immédiate vers team.html via meta refresh et script inline
- Utilise meta http-equiv=refresh pour rediriger même sans JS
- Ajoute script inline dans Head pour redirection JS immédiate
- Fonctionne avec l'export statique Next.js
2025-12-09 15:18:10 +01:00
syoul
f149571673 fix: ne pas écraser config.default.json
- Garder le config.default.json original du package
- Ne copier que vers config.json (pas config.default.json)
- Évite erreur TypeScript 'Property icon does not exist on type never'

Le type de social est inféré depuis config.default.json
2025-12-09 15:12:46 +01:00
syoul
2dd08c0d46 fix: simplifier team-page.tsx pour éviter erreurs modules
- Page team.tsx redirige maintenant vers team.html
- Évite les imports cytoscape/echarts qui causent MODULE_NOT_FOUND
- team.html contient les vraies visualisations avec chargement CDN

Corrige l'erreur npm run build dans Docker
2025-12-09 15:00:54 +01:00
syoul
982d45994d fix: synchroniser config.json et radar/ avec radar-business/
- config.json avec rings adopt/trial/assess/hold
- radar/2025-01-15/* synchronisé depuis radar-business/
- Corrige 'invalid ring' pendant build:data
2025-12-09 14:56:11 +01:00
syoul
c008d38d10 fix: ajouter config.default.json pour build techradar
- Copie de config-business.json vers .techradar/data/config.default.json
- Évite l'erreur MODULE_NOT_FOUND sur config.default.json pendant build:data
2025-12-09 14:50:39 +01:00
syoul
c76f5e958c chore: assouplir build TS page équipe
- Ajout @ts-nocheck en tête de team-page.tsx
- Suppression des imports dynamiques inutilisés (évite noUnusedLocals)

Réduit les risques d'échec npm run build
2025-12-09 14:48:10 +01:00
syoul
f6f138ea97 build: inclure dossiers docker dans contexte
- Retrait de l'exclusion /docker dans .dockerignore
- Permet de copier add_team_link.* et team-page.tsx durant le build

Corrige l'erreur 'checksum ... /docker/add_team_link.sh not found'
2025-12-09 14:45:31 +01:00
syoul
9264854a54 build: supprimer heredoc des scripts team
- Déplace add_team_link.py et add_team_link.sh dans docker/
- Remplace les heredocs par des COPY dans Dockerfile.business
- Évite l'erreur de parsing 'unknown instruction: import'

Compatibilité Portainer sans syntaxe heredoc.
2025-12-09 14:41:57 +01:00
syoul
ae6f88a02e build: remplacer heredoc team.tsx par COPY
- Ajout docker/team-page.tsx avec le composant React complet
- Remplacement du heredoc dans Dockerfile.business par un COPY
- Évite les erreurs de parsing Docker (unknown instruction: import)

Assure la compatibilité Portainer sans syntaxe heredoc
2025-12-09 14:39:31 +01:00
syoul
a9f02bd47d build: activer syntaxe heredoc dockerfile 1.4
- Ajout directive # syntax=docker/dockerfile:1.4
- Permet l'usage des heredocs dans le Dockerfile

Doit supprimer l'erreur 'unknown instruction: import' lors du parsing
2025-12-09 14:27:00 +01:00
syoul
eec2e0c52f fix: corriger structure heredoc Dockerfile
- Ajouter commande RUN manquante pour script Python
- Fermer proprement heredoc team.tsx avec EOF
- Ouvrir heredoc Python avec PYEOF
- Structure Dockerfile maintenant cohérente

Corrige erreur 'unknown instruction: import'
2025-12-09 14:21:28 +01:00
syoul
aa04c62904 fix: nettoyage HTML erroné du Dockerfile
- Suppression contenu HTML résiduel après remplacement team.tsx
- HTML interprété comme instructions Docker causait erreur parsing
- Dockerfile maintenant propre et valide

Corrige erreur 'unknown instruction: <html'
2025-12-09 14:20:32 +01:00
syoul
42b829fffc docs: mise à jour guide page équipe
- Architecture mise à jour (vraie page React vs HTML intégré)
- Suppression références team.html obsolètes
- Ajout bibliothèques React (hooks, refs, dynamic import)
- Processus build actualisé (installation dépendances)
- Personnalisation adaptée à l'approche React

Documentation alignée sur nouvelle implémentation
2025-12-09 14:18:59 +01:00
syoul
6ecf94dc9f fix: vraie page React pour /team avec import dynamique
- Remplace HTML intégré par vraie page React
- Import dynamique de Cytoscape et ECharts (évite erreurs SSR)
- États React pour gestion des onglets et données
- Refs pour containers des graphiques
- Installation dépendances cytoscape et echarts-for-react
- Gestion erreurs et états de chargement

Résout problème scripts non exécutés dans contexte React
2025-12-09 14:18:08 +01:00
syoul
b7911fcdae cleanup: suppression références team-static.html inutiles
- Suppression copie team-static.html du Dockerfile (plus nécessaire)
- Suppression vérifications team-static.html des logs de build
- Suppression fichier public/team-static.html (intégration directe)

Nettoyage suite à l'intégration directe du HTML dans la page React
2025-12-09 14:10:46 +01:00
syoul
d8e9503cc7 fix: page équipe intègre directement HTML statique
- Page team.tsx charge directement le HTML des visualisations
- Plus de redirection, le contenu est rendu dans React
- Évite les conflits de routing Next.js
- Scripts Cytoscape/ECharts intégrés directement
- Contenu team-visualization-data.json chargé depuis la page React

Cette approche contourne complètement les problèmes de déploiement statique
2025-12-09 14:10:23 +01:00
syoul
166248078f fix: correction copie team-static.html et team-visualization-data.json
- Déplacement de la copie de team-static.html dans la section principale de copie
- Déplacement de la copie de team-visualization-data.json dans la section principale
- Suppression des copies dupliquées qui étaient mal placées
- Maintenant les fichiers seront copiés correctement lors du build

Ces fichiers étaient absents du déploiement, causant l'affichage du radar au lieu des visualisations équipe
2025-12-09 14:00:01 +01:00
syoul
f431a0b7cc fix: approche HTML statique pour éviter conflits React
- Nouvelle page team-static.html : page HTML pure sans React
- team.tsx redirige simplement vers /team-static.html
- Évite tous les conflits d'injection DOM dans React
- team-static.html copié dans out/ lors du build
- Contient tous les logs de débogage et visualisations équipe

Cette approche contourne complètement les problèmes React/DOM
2025-12-09 13:35:28 +01:00
syoul
4b111ef02d fix: page équipe charge directement contenu team.html
- Au lieu de rediriger, la page Next.js charge et injecte team.html
- Exécution des scripts JavaScript et injection du CSS
- Gestion d'erreur si team.html ne se charge pas
- Logs détaillés pour diagnostiquer le processus

Cette approche évite les problèmes de redirection et assure que :
- team.html se charge correctement
- Les scripts s'exécutent dans le contexte Next.js
- Les visualisations s'affichent
2025-12-09 13:13:31 +01:00
syoul
2d72898bdc debug: logs détaillés toutes les étapes team.html
- Log au chargement des scripts externes (Cytoscape, ECharts)
- Log au démarrage de loadData()
- Log au début de chaque fonction d'initialisation
- Vérifications de disponibilité des données

Ces logs permettront de voir exactement où le processus bloque :
- Scripts externes se chargent-ils ?
- Données se chargent-elles ?
- Fonctions d'initialisation s'exécutent-elles ?
- Graphiques se créent-ils ?
2025-12-09 13:09:58 +01:00
syoul
78021a5496 debug: logs détaillés chargement données équipe
- Logs console détaillés dans team.html pour diagnostiquer le chargement
- Message de fallback informatif si données non chargées
- Vérifications build pour team-visualization-data.json
- Diagnostic pour identifier pourquoi les visualisations n'apparaissent pas

Les logs console aideront à identifier si le problème vient :
- Du chargement des données JSON
- De l'initialisation des graphiques Cytoscape/ECharts
- De l'accès aux fichiers statiques
2025-12-09 13:04:51 +01:00
syoul
a4bc477520 fix: redirection directe vers team.html + bouton retour
- Page team.tsx fait redirection immédiate vers /team.html (évite conflits React)
- Ajout bouton retour dans header de team.html vers l'accueil
- Évite tous les conflits entre scripts JavaScript et React

Cette approche simple devrait :
- Afficher les visualisations équipe correctement
- Permettre la navigation retour avec le bouton ajouté
2025-12-09 13:01:27 +01:00