- Introduced a new structure for services in `src/services/` to improve organization by domain, including core, analytics, data management, integrations, and task management. - Moved relevant files to their new locations and updated all internal and external imports accordingly. - Updated `TODO.md` to reflect the new service organization and outlined phases for further refactoring.
8.5 KiB
8.5 KiB
TowerControl v2.0 - Gestionnaire de tâches moderne
Autre Todos
- Désactiver le hover sur les taskCard
🔧 Phase 6: Fonctionnalités avancées (Priorité 6)
6.1 Gestion avancée des tâches
- Actions en lot (sélection multiple)
- Sous-tâches et hiérarchie
- Dates d'échéance et rappels
- Assignation et collaboration
- Templates de tâches
6.2 Personnalisation et thèmes
- Mode sombre/clair
- Personnalisation des couleurs
- Configuration des colonnes Kanban
- Préférences utilisateur
🚀 Phase 7: Intégrations futures (Priorité 7)
7.1 Intégrations externes (optionnel)
- Import/Export depuis d'autres outils
- API webhooks pour intégrations
- Synchronisation cloud (optionnel)
- Notifications push
7.2 Optimisations et performance
- Optimisation des requêtes DB
- Pagination et virtualisation
- Cache côté client
- PWA et mode offline
🚀 Nouvelles idées & fonctionnalités futures
🔄 Intégration TFS/Azure DevOps
- Lecture des Pull Requests TFS : Synchronisation des PR comme tâches
- PR arrivent en backlog avec filtrage par team project
- Synchronisation aussi riche que Jira (statuts, assignés, commentaires)
- Filtrage par team project, repository, auteur
- Architecture plug-and-play pour intégrations
- Refactoriser pour interfaces génériques d'intégration
- Interface
IntegrationServicecommune (Jira, TFS, GitHub, etc.) - UI générique de configuration des intégrations
- Système de plugins pour ajouter facilement de nouveaux services
📋 Daily - Gestion des tâches non cochées
- Section des tâches en attente
- Liste de toutes les todos non cochées (historique complet)
- Filtrage par date (7/14/30 jours), catégorie (tâches/réunions), ancienneté
- Action "Archiver" pour les tâches ni résolues ni à faire
- Section repliable dans la page Daily (sous les sections Hier/Aujourd'hui)
- Bouton "Déplacer à aujourd'hui" pour les tâches non résolues
- Indicateurs visuels d'ancienneté (couleurs vert→rouge)
- Actions par tâche : Cocher, Archiver, Supprimer
- Statut "Archivé" basique
- Marquage textuel [ARCHIVÉ] dans le texte de la tâche
- Interface pour voir les tâches archivées (visuellement distinctes)
- Possibilité de désarchiver une tâche
- Champ dédié en base de données (actuellement via texte)
🎯 Jira - Suivi des demandes en attente
- Page "Jiras en attente"
- Liste des Jiras créés par moi mais non assignés à mon équipe
- Suivi des demandes formulées à d'autres équipes
- Filtrage par projet, équipe cible, ancienneté
- Nouveau modèle de données
- Table séparée pour les "demandes en attente" (différent des tâches Kanban)
- Champs spécifiques : demandeur, équipe cible, statut de traitement
- Notifications quand une demande change de statut
🏗️ Architecture & technique
- Système d'intégrations modulaire
- Interface
IntegrationProviderstandardisée - Configuration dynamique des intégrations
- Gestion des credentials par intégration
- Interface
- Modèles de données étendus
PullRequestpour TFS/GitHubPendingRequestpour les demandes JiraArchivedTaskpour les daily archivées
- UI générique
- Composants réutilisables pour toutes les intégrations
- Configuration unifiée des filtres et synchronisations
- Dashboard multi-intégrations
🔄 Refactoring Services par Domaine
Organisation cible des services:
src/services/
├── core/ # Services fondamentaux
├── analytics/ # Analytics et métriques
├── data-management/# Backup, système, base
├── integrations/ # Services externes
├── task-management/# Gestion des tâches
Phase 1: Services Core (infrastructure) ✅
- Déplacer
database.ts→core/database.ts- Corriger tous les imports internes des services
- Corriger import dans scripts/reset-database.ts
- Déplacer
system-info.ts→core/system-info.ts- Corriger imports dans actions/system
- Corriger import dynamique de backup
- Déplacer
user-preferences.ts→core/user-preferences.ts- Corriger 13 imports externes (actions, API routes, pages)
- Corriger 3 imports internes entre services
Phase 2: Analytics & Métriques
- Déplacer
analytics.ts→analytics/analytics.ts- Corriger imports dans hooks/components analytics
- Déplacer
metrics.ts→analytics/metrics.ts- Corriger import dans
actions/metrics.ts
- Corriger import dans
- Déplacer
manager-summary.ts→analytics/manager-summary.ts- Corriger imports dans components dashboard
Phase 3: Data Management
- Déplacer
backup.ts→data-management/backup.ts- Corriger imports dans backup-scheduler et actions
- Déplacer
backup-scheduler.ts→data-management/backup-scheduler.ts- Corriger imports dans API routes
Phase 4: Task Management
- Déplacer
tasks.ts→task-management/tasks.ts- Corriger imports dans actions/tasks, hooks/useTasks
- Déplacer
tags.ts→task-management/tags.ts- Corriger import dans
actions/tags.ts
- Corriger import dans
- Déplacer
daily.ts→task-management/daily.ts- Corriger imports dans hooks/useDaily, actions/daily
Phase 5: Intégrations (déjà partiellement fait)
- Déplacer
tfs.ts→integrations/tfs.ts- Corriger imports dans actions/tfs, API routes TFS, components TFS
- Déplacer services Jira →
integrations/jira/jira.ts→integrations/jira/jira.tsjira-scheduler.ts→integrations/jira/scheduler.tsjira-analytics.ts→integrations/jira/analytics.tsjira-analytics-cache.ts→integrations/jira/analytics-cache.tsjira-advanced-filters.ts→integrations/jira/advanced-filters.tsjira-anomaly-detection.ts→integrations/jira/anomaly-detection.ts- Corriger tous les imports Jira dans actions, API routes, hooks
Points d'attention pour chaque service:
- Identifier tous les imports du service (grep)
- Déplacer le fichier vers le nouveau dossier
- Corriger les imports externes (actions, API, hooks, components)
- Corriger les imports internes entre services
- Tester que l'app fonctionne toujours
- Commit le déplacement d'un service à la fois
### 👥 Gestion multi-utilisateurs (PROJET MAJEUR)
#### **Architecture actuelle → Multi-tenant**
- **Problème** : App mono-utilisateur avec données globales
- **Solution** : Transformation en app multi-utilisateurs avec isolation des données
#### **Plan de migration**
- [ ] **Phase 1: Authentification**
- [ ] Système de login/mot de passe (NextAuth.js ou custom)
- [ ] Gestion des sessions sécurisées
- [ ] Pages de connexion/inscription/mot de passe oublié
- [ ] Middleware de protection des routes
- [ ] **Phase 2: Modèle de données multi-tenant**
- [ ] Ajouter `userId` à toutes les tables (tasks, daily, tags, preferences, etc.)
- [ ] Migration des données existantes vers un utilisateur par défaut
- [ ] Contraintes de base de données pour l'isolation
- [ ] Index sur `userId` pour les performances
- [ ] **Phase 3: Services et API**
- [ ] Modifier tous les services pour filtrer par `userId`
- [ ] Middleware d'injection automatique du `userId` dans les requêtes
- [ ] Validation que chaque utilisateur ne voit que ses données
- [ ] API d'administration (optionnel)
- [ ] **Phase 4: UI et UX**
- [ ] Header avec profil utilisateur et déconnexion
- [ ] Onboarding pour nouveaux utilisateurs
- [ ] Gestion du profil utilisateur
- [ ] Partage optionnel entre utilisateurs (équipes)
#### **Considérations techniques**
- **Base de données** : Ajouter `userId` partout + contraintes
- **Sécurité** : Validation côté serveur de l'isolation des données
- **Performance** : Index sur `userId`, pagination pour gros volumes
- **Migration** : Script de migration des données existantes
---
*Focus sur l'expérience utilisateur et le design moderne. App standalone prête pour évoluer vers une plateforme d'intégration complète.*