266 lines
9.5 KiB
Markdown
266 lines
9.5 KiB
Markdown
# Améliorations Interface Graphique - Recommandations
|
|
|
|
**Date**: 2 mars 2026
|
|
**Fichier**: `Pseudonymisation_Gui_V5.py`
|
|
|
|
## Analyse Actuelle
|
|
|
|
L'interface est bien conçue avec :
|
|
- ✅ Design moderne et épuré
|
|
- ✅ Thème système natif (sv_ttk)
|
|
- ✅ Vue unique en 2 étapes
|
|
- ✅ Feedback visuel (progression, résultats)
|
|
- ✅ Support VLM optionnel
|
|
|
|
## Améliorations Recommandées
|
|
|
|
### 1. Afficher les Métriques de Qualité 🎯
|
|
|
|
**Problème**: L'utilisateur ne voit pas la qualité de l'anonymisation (Precision/Recall).
|
|
|
|
**Solution**: Ajouter une carte de métriques dans la section résultats :
|
|
|
|
```python
|
|
# Après les 3 cartes existantes (fichiers, données masquées, erreurs)
|
|
self._stat_quality = self._make_stat_card(
|
|
stats_row, "100%", "qualité (F1-Score)",
|
|
CLR_GREEN, CLR_GREEN_LIGHT, 3
|
|
)
|
|
```
|
|
|
|
**Calcul**: Utiliser `evaluation/quality_evaluator.py` si annotations disponibles, sinon afficher "N/A".
|
|
|
|
### 2. Indicateur de Fuites 🔒
|
|
|
|
**Problème**: Pas de feedback sur les fuites potentielles détectées.
|
|
|
|
**Solution**: Ajouter un indicateur de sécurité :
|
|
|
|
```python
|
|
# Badge "0 fuite détectée" ou "⚠️ X fuites potentielles"
|
|
self._leak_badge = tk.Label(
|
|
self._results_frame,
|
|
text="🔒 0 fuite détectée",
|
|
font=self._f_body_bold,
|
|
bg=CLR_GREEN_LIGHT, fg=CLR_GREEN,
|
|
padx=12, pady=6
|
|
)
|
|
```
|
|
|
|
**Calcul**: Utiliser `evaluation/leak_scanner.py` sur les textes anonymisés.
|
|
|
|
### 3. Temps de Traitement et Vitesse ⏱️
|
|
|
|
**Problème**: Pas d'info sur les performances.
|
|
|
|
**Solution**: Afficher le temps total et la vitesse moyenne :
|
|
|
|
```python
|
|
# Dans la section résultats
|
|
self._perf_label = tk.Label(
|
|
self._results_frame,
|
|
text="Traité en 2m 15s (1.2s/document)",
|
|
font=self._f_small,
|
|
bg=CLR_BG, fg=CLR_TEXT_SECONDARY
|
|
)
|
|
```
|
|
|
|
### 4. Prévisualisation Avant/Après 👁️
|
|
|
|
**Problème**: L'utilisateur ne peut pas voir un exemple d'anonymisation.
|
|
|
|
**Solution**: Ajouter un bouton "Voir un exemple" qui ouvre une fenêtre avec :
|
|
- Texte original (extrait)
|
|
- Texte anonymisé
|
|
- Liste des PII détectés
|
|
|
|
```python
|
|
self.btn_preview = tk.Button(
|
|
self._results_frame,
|
|
text="Voir un exemple d'anonymisation",
|
|
font=self._f_button,
|
|
bg=CLR_PRIMARY, fg="white",
|
|
command=self._show_preview
|
|
)
|
|
```
|
|
|
|
### 5. Options Avancées (Optionnel) ⚙️
|
|
|
|
**Problème**: Pas de contrôle sur les paramètres d'anonymisation.
|
|
|
|
**Solution**: Ajouter un bouton "Options avancées" qui ouvre une fenêtre modale avec :
|
|
- ☑️ Activer/désactiver VLM
|
|
- ☑️ Activer/désactiver filtre hôpital
|
|
- ☑️ Générer PDF vectoriel (en plus du raster)
|
|
- ☑️ Activer validation post-anonymisation
|
|
- 🎚️ Seuil de confiance NER (slider)
|
|
|
|
### 6. Rapport d'Audit Téléchargeable 📄
|
|
|
|
**Problème**: Pas de rapport consolidé des résultats.
|
|
|
|
**Solution**: Générer un rapport HTML/PDF avec :
|
|
- Statistiques globales
|
|
- Liste des fichiers traités
|
|
- Métriques de qualité
|
|
- Temps de traitement
|
|
- Fuites détectées (si applicable)
|
|
|
|
```python
|
|
self.btn_report = tk.Button(
|
|
self._results_frame,
|
|
text="Télécharger le rapport d'audit",
|
|
font=self._f_button,
|
|
bg=CLR_TEXT_SECONDARY, fg="white",
|
|
command=self._generate_report
|
|
)
|
|
```
|
|
|
|
### 7. Gestion des Erreurs Améliorée ⚠️
|
|
|
|
**Problème**: Les erreurs sont juste comptées, pas détaillées.
|
|
|
|
**Solution**: Ajouter un bouton "Voir les erreurs" qui liste :
|
|
- Nom du fichier
|
|
- Type d'erreur
|
|
- Message d'erreur
|
|
- Action suggérée
|
|
|
|
### 8. Mode Batch avec Pause/Reprise ⏸️
|
|
|
|
**Problème**: Impossible de mettre en pause un traitement long.
|
|
|
|
**Solution**: Ajouter des boutons :
|
|
- ⏸️ Pause
|
|
- ▶️ Reprendre
|
|
- ⏹️ Arrêter
|
|
|
|
### 9. Historique des Traitements 📊
|
|
|
|
**Problème**: Pas de trace des traitements précédents.
|
|
|
|
**Solution**: Ajouter un onglet "Historique" avec :
|
|
- Date/heure
|
|
- Dossier traité
|
|
- Nombre de fichiers
|
|
- Métriques
|
|
- Bouton "Retraiter"
|
|
|
|
### 10. Drag & Drop 🖱️
|
|
|
|
**Problème**: L'utilisateur doit cliquer pour choisir un dossier.
|
|
|
|
**Solution**: Permettre le glisser-déposer d'un dossier sur la zone de sélection.
|
|
|
|
```python
|
|
self._folder_zone.drop_target_register(DND_FILES)
|
|
self._folder_zone.dnd_bind('<<Drop>>', self._on_drop)
|
|
```
|
|
|
|
## Priorités d'Implémentation
|
|
|
|
### Priorité 1 (Impact Élevé, Effort Faible)
|
|
1. ✅ Temps de traitement et vitesse
|
|
2. ✅ Indicateur de fuites
|
|
3. ✅ Gestion des erreurs améliorée
|
|
|
|
### Priorité 2 (Impact Élevé, Effort Moyen)
|
|
4. ✅ Métriques de qualité
|
|
5. ✅ Prévisualisation avant/après
|
|
6. ✅ Rapport d'audit téléchargeable
|
|
|
|
### Priorité 3 (Impact Moyen, Effort Élevé)
|
|
7. ⚙️ Options avancées
|
|
8. ⏸️ Mode batch avec pause/reprise
|
|
9. 📊 Historique des traitements
|
|
10. 🖱️ Drag & drop
|
|
|
|
## Mockup Proposé (Section Résultats)
|
|
|
|
```
|
|
┌─────────────────────────────────────────────────────────────┐
|
|
│ Résultats │
|
|
├─────────────────────────────────────────────────────────────┤
|
|
│ │
|
|
│ ┌──────────┐ ┌──────────┐ ┌──────────┐ ┌──────────┐ │
|
|
│ │ 125 │ │ 12,450 │ │ 2 │ │ 100% │ │
|
|
│ │ fichiers │ │ données │ │ erreurs │ │ qualité │ │
|
|
│ │ traités │ │ masquées │ │ │ │(F1-Score)│ │
|
|
│ └──────────┘ └──────────┘ └──────────┘ └──────────┘ │
|
|
│ │
|
|
│ 🔒 0 fuite détectée │
|
|
│ ⏱️ Traité en 3m 45s (1.8s/document) │
|
|
│ │
|
|
│ ┌────────────────────────────────────────────────────┐ │
|
|
│ │ Ouvrir le dossier de résultats │ │
|
|
│ └────────────────────────────────────────────────────┘ │
|
|
│ │
|
|
│ ┌────────────────────────────────────────────────────┐ │
|
|
│ │ Voir un exemple d'anonymisation │ │
|
|
│ └────────────────────────────────────────────────────┘ │
|
|
│ │
|
|
│ ┌────────────────────────────────────────────────────┐ │
|
|
│ │ Télécharger le rapport d'audit │ │
|
|
│ └────────────────────────────────────────────────────┘ │
|
|
│ │
|
|
│ Voir le journal détaillé ▼ │
|
|
│ │
|
|
└─────────────────────────────────────────────────────────────┘
|
|
```
|
|
|
|
## Code Exemple : Indicateur de Fuites
|
|
|
|
```python
|
|
def _check_leaks(self, output_dir: Path) -> int:
|
|
"""Vérifie les fuites dans les textes anonymisés."""
|
|
from evaluation.leak_scanner import LeakScanner
|
|
|
|
scanner = LeakScanner()
|
|
leak_count = 0
|
|
|
|
for txt_file in output_dir.glob("*.pseudonymise.txt"):
|
|
with open(txt_file, 'r', encoding='utf-8') as f:
|
|
content = f.read()
|
|
report = scanner.scan_text(content)
|
|
leak_count += len(report.leaks)
|
|
|
|
return leak_count
|
|
|
|
def _update_leak_indicator(self, leak_count: int):
|
|
"""Met à jour l'indicateur de fuites."""
|
|
if leak_count == 0:
|
|
self._leak_badge.configure(
|
|
text="🔒 0 fuite détectée",
|
|
bg=CLR_GREEN_LIGHT, fg=CLR_GREEN
|
|
)
|
|
else:
|
|
self._leak_badge.configure(
|
|
text=f"⚠️ {leak_count} fuite{'s' if leak_count > 1 else ''} potentielle{'s' if leak_count > 1 else ''}",
|
|
bg=CLR_RED_LIGHT, fg=CLR_RED
|
|
)
|
|
```
|
|
|
|
## Accessibilité
|
|
|
|
- ✅ Contraste des couleurs conforme WCAG AA
|
|
- ✅ Tailles de police lisibles
|
|
- ⚠️ Ajouter des labels ARIA pour les lecteurs d'écran
|
|
- ⚠️ Support navigation clavier (Tab, Enter, Espace)
|
|
- ⚠️ Tooltips informatifs sur tous les boutons
|
|
|
|
## Tests Utilisateur Suggérés
|
|
|
|
1. Tester avec un utilisateur non-technique
|
|
2. Mesurer le temps pour comprendre l'interface
|
|
3. Vérifier la compréhension des métriques
|
|
4. Valider l'utilité des fonctionnalités proposées
|
|
|
|
## Conclusion
|
|
|
|
L'interface actuelle est solide. Les améliorations prioritaires sont :
|
|
1. **Indicateur de fuites** (sécurité)
|
|
2. **Temps de traitement** (feedback)
|
|
3. **Métriques de qualité** (confiance)
|
|
|
|
Ces 3 ajouts simples augmenteraient significativement la valeur perçue et la confiance de l'utilisateur.
|