Metadata-Version: 2.4
Name: personnalisation-admin-django-IIT
Version: 0.3.0
Summary: Package Django réutilisable pour personnaliser l'interface d'administration avec graphiques dynamiques, grilles de données et thèmes modernes
Home-page: https://github.com/VOTRE_USERNAME/django-admin-custom
Author: Bléou Christ, Sylla Scheickna, Kossonou Marie Joseph, Kouassi Nissi, Yoboué Romuald
Author-email: 
License: MIT
Keywords: django,admin,customization,charts,grids,themes
Classifier: Development Status :: 3 - Alpha
Classifier: Environment :: Web Environment
Classifier: Framework :: Django
Classifier: Framework :: Django :: 4.2
Classifier: Framework :: Django :: 5.0
Classifier: Intended Audience :: Developers
Classifier: License :: OSI Approved :: MIT License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Topic :: Internet :: WWW/HTTP
Classifier: Topic :: Internet :: WWW/HTTP :: Dynamic Content
Requires-Python: >=3.10
Description-Content-Type: text/markdown
Requires-Dist: Django<6.0,>=4.2
Provides-Extra: dev
Requires-Dist: pytest>=7.0; extra == "dev"
Requires-Dist: pytest-django>=4.5.0; extra == "dev"
Requires-Dist: black>=23.0; extra == "dev"
Requires-Dist: flake8>=6.0; extra == "dev"
Dynamic: home-page
Dynamic: requires-python

# Admin Custom - Personnalisation Complète de l'Admin Django

## 📋 À propos du projet

**Admin Custom** est un package Django réutilisable qui transforme l'interface d'administration Django standard en une expérience moderne, personnalisable et professionnelle. Ce projet répond au besoin de créer une interface admin sur-mesure sans avoir à réécrire tout le système d'administration Django.

### 🎯 Pourquoi ce projet ?

L'administration Django par défaut, bien que fonctionnelle, présente plusieurs limitations :

- **Design obsolète** : L'interface standard manque de modernité et de personnalisation
- **Configuration manuelle fastidieuse** : Chaque modèle doit être enregistré manuellement
- **Manque de flexibilité** : Difficile d'ajouter des fonctionnalités personnalisées (graphiques, dashboards)
- **Pas de système de thèmes** : Impossible de changer l'apparence sans modifier le code
- **Structure non réutilisable** : Les personnalisations sont liées à un projet spécifique

**Admin Custom** résout tous ces problèmes en offrant :

✅ **Auto-découverte automatique** : Tous vos modèles sont détectés et enregistrés automatiquement
✅ **7 thèmes personnalisables** : Choisissez parmi plusieurs palettes de couleurs sobres et professionnelles
✅ **Dashboard interactif** : Graphiques dynamiques et grilles de données configurables
✅ **Package réutilisable** : Installez-le dans n'importe quel projet Django
✅ **Navigation moderne** : Interface intuitive avec indicateurs visuels
✅ **Effets visuels avancés** : Glassmorphism et animations fluides

## 🚀 Installation et lancement

### Prérequis

- Python 3.8 ou supérieur
- Django 4.0 ou supérieur
- pip (gestionnaire de paquets Python)

### Installation

1. **Cloner le projet** (si vous travaillez depuis le dépôt Git)
2. **Créer un environnement virtuel** (recommandé)

   ```bash
   python -m venv venv
   ```
3. **Activer l'environnement virtuel**

   Sur Windows :

   ```bash
   venv\Scripts\activate
   ```

   Sur Linux/Mac :

   ```bash
   source venv/bin/activate
   ```
4. **Installer les dépendances**

   ```bash
   pip install -r requirements.txt
   ```

   Si le fichier `requirements.txt` n'existe pas, installez Django :

   ```bash
   pip install django
   ```
5. **Configurer la base de données**

   ```bash
   python manage.py migrate
   ```
6. **Créer un superutilisateur** (pour accéder à l'admin)

   ```bash
   python manage.py createsuperuser
   ```

   Suivez les instructions pour créer un compte administrateur.
7. **Lancer le serveur de développement**

   ```bash
   python manage.py runserver
   ```
8. **Accéder à l'interface admin**

   Ouvrez votre navigateur et allez à :

   ```
   http://127.0.0.1:8000/admin/
   ```

   Connectez-vous avec les identifiants du superutilisateur créé à l'étape 6.

## 🎨 Fonctionnalités principales

### Auto-découverte des modèles

Aucun enregistrement manuel nécessaire ! Tous vos modèles sont automatiquement détectés et enregistrés dans l'admin personnalisé. Il suffit de créer vos fichiers `admin.py` normalement avec `@admin.register()`, et le système fait le reste.

### Système de thèmes

7 thèmes disponibles avec des palettes de couleurs sobres et professionnelles :

- **Default** : Gris-bleu sobre et classique
- **Dark** : Mode sombre moderne
- **Liquid Glass** : Effets glassmorphism élégants
- **Nostalgie** : Style rétro discret
- **Océan** : Palette bleu-gris apaisante
- **Sunset** : Tons beige-rose chaleureux
- **Forêt** : Vert-gris naturel

Chaque thème adapte automatiquement :

- Les couleurs de fond et de texte
- La navigation
- Les cartes et modules
- Les boutons et formulaires
- Les tableaux

### Dashboard interactif

- **Graphiques dynamiques** : Visualisez vos données avec des graphiques configurables
- **Grilles de données** : Créez des tableaux personnalisés avec filtres et recherche
- **Statistiques en temps réel** : Suivez les métriques importantes de votre application

### Navigation personnalisée

- Barre de navigation moderne avec indicateurs visuels
- Liens actifs mis en évidence
- Transitions fluides entre les pages
- Responsive et adaptatif

## 📁 Structure du projet

```
AGILE Méth/
├── admin_custom/          # Package principal
│   ├── static/            # Fichiers statiques (CSS, JS, images)
│   ├── templates/         # Templates personnalisés
│   ├── admin_site.py      # CustomAdminSite
│   ├── autodiscover.py    # Système d'auto-découverte
│   └── ...
├── sandbox/               # Projet Django de démonstration
│   ├── settings.py
│   ├── urls.py
│   └── ...
├── sales/                 # Exemple d'app avec modèles
├── catalog/               # Exemple d'app avec modèles
├── accounts/              # Exemple d'app avec modèles
├── manage.py
├── requirements.txt
└── README.md
```

## 🔧 Configuration

### Utilisation dans votre projet

1. **Ajouter `admin_custom` à `INSTALLED_APPS`** dans `settings.py`
2. **Configurer les URLs** dans `urls.py` :

   ```python
   from admin_custom.admin_site import custom_admin_site
   from admin_custom.autodiscover import autodiscover_models

   # Auto-découvrir tous les modèles
   autodiscover_models(custom_admin_site, exclude_apps=['admin_custom'])

   urlpatterns = [
       path('admin/', custom_admin_site.urls),
   ]
   ```
3. **C'est tout !** Vos modèles sont automatiquement détectés.

### Personnalisation avancée

Consultez le fichier `admin_custom/AUTODISCOVERY.md` pour plus de détails sur :

- L'exclusion d'apps ou de modèles spécifiques
- La configuration via `settings.py`
- Les cas d'usage avancés

## 📚 Documentation

- **AUTODISCOVERY.md** : Documentation complète du système d'auto-découverte
- **Code source** : Commentaires détaillés dans tous les fichiers Python

## 🛠️ Commandes utiles

### Développement

```bash
# Lancer le serveur
python manage.py runserver

# Créer des migrations
python manage.py makemigrations

# Appliquer les migrations
python manage.py migrate

# Créer un superutilisateur
python manage.py createsuperuser

# Accéder au shell Django
python manage.py shell

# Collecter les fichiers statiques (production)
python manage.py collectstatic
```

### Nettoyage de la base de données

```bash
# Nettoyer les commandes tout en gardant des dates variées
python manage.py cleanup_orders --keep 50
```

## 🎯 Cas d'usage

Ce package est idéal pour :

- **Applications métier** : Interface admin professionnelle pour vos clients
- **Projets internes** : Dashboard moderne pour la gestion de données
- **Développement rapide** : Pas besoin de configurer chaque modèle manuellement
- **Projets réutilisables** : Installez le package dans plusieurs projets

## 🔒 Sécurité

- Toutes les fonctionnalités respectent le système de permissions Django
- Les utilisateurs doivent être authentifiés pour accéder à l'admin
- Les permissions par modèle sont préservées

## 📝 Notes importantes

- Ce projet est en développement actif
- Les thèmes peuvent être personnalisés via les variables CSS
- L'auto-découverte fonctionne avec tous les modèles Django standards
- Compatible avec Django 4.0+

## 🤝 Contribution

Ce projet est développé dans le cadre d'une étude sur les méthodes agiles et la personnalisation de l'administration Django.

## 📄 Licence

Ce projet est fourni à des fins éducatives et de démonstration.

---

**Développé avec ❤️ pour améliorer l'expérience d'administration Django**
