yann64
ff615ca0a1
Suppression de l'export GEDCOM
...
- Routes export.source et export.recherche supprimées
- ExportController : méthodes source() et recherche() supprimées,
imports GedcomExportService/DbCompat/Releve/SourceStatus/DB retirés
- Boutons GEDCOM retirés de sources/show, releves/index et recherche/index
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-05 20:01:33 +02:00
yann64
fdd81977c2
Export CSV des relevés d'une source
...
- ExportController::sourceCsv() : génère un CSV avec BOM UTF-8 (compatible Excel)
séparateur point-virgule, en-têtes = labels des champs, valeurs formatées
(dates avec calendrier si non grégorien, lieux = nom_long, booléens Oui/Non)
- Route GET export/source/{source}/csv → export.source.csv
- Boutons ↓ CSV et ↓ GEDCOM dans la section relevés de la fiche source
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-05 19:39:21 +02:00
yann64
bc4dd29ae7
Fix compatibilité MySQL : NULLS LAST et order withCount/select
...
- DbCompat::nullsLast() : syntaxe portable pgsql/mysql pour ORDER BY NULLS LAST
- RechercheController, ExportController : remplace 'nom ASC NULLS LAST' (pgsql only)
- CarteController : select() avant withCount() pour ne pas effacer le COUNT subquery
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-05 18:46:31 +02:00
yann64
236d37976c
Compatibilité MySQL + suppression de Redis comme dépendance requise
...
DbCompat (app/Support/DbCompat.php) :
- like() → ilike (pgsql) ou like (mysql)
- jsonRegexRaw() → data::text ~* ? (pgsql) ou CAST(data AS CHAR) REGEXP ? (mysql)
- ftsRaw() → to_tsvector/plainto_tsquery (pgsql) ou null/fallback LIKE (mysql)
- generatedJsonCol() → syntaxe colonne générée JSON selon le SGBD
- generatedJsonNestedCol() → idem pour champs imbriqués
Migrations :
- create_releves_table : JSON/JSONB selon SGBD, colonnes générées adaptées,
index GIN uniquement pour PostgreSQL
Controllers :
- LieuController (search + index) : ilike → DbCompat::like()
- Admin\UserController (index) : ilike → DbCompat::like()
- RechercheController : FTS + regex → DbCompat, fallback LIKE MySQL
- ExportController : regex → DbCompat::jsonRegexRaw()
UpdateService :
- backupDatabase() : pg_dump (pgsql) ou mysqldump (mysql)
- restoreBackup() : psql (pgsql) ou mysql (mysql)
Docker :
- docker-compose.yml : suppression Redis (plus requis)
- docker-compose.mysql.yml : nouveau fichier pour dev MySQL
- docker-compose.prod.yml : suppression Redis, DB_IMAGE configurable,
CACHE_STORE/SESSION_DRIVER/QUEUE_CONNECTION → database par défaut
.env.example :
- DB_PORT commenté avec les deux valeurs (5432/3306)
- CACHE_STORE et QUEUE_CONNECTION commentés (database par défaut)
- Redis marqué optionnel
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-04 18:13:42 +02:00
yann64
d064f8d28e
Étapes 6-9 + types de lieux + picker + filtres
...
- Étape 6 : formulaire de saisie dynamique des relevés (piloté par source_type_fields, calendriers grégorien/julien/républicain)
- Étape 7 : workflow de statut des sources + notifications mail+DB (SourceAValider, SourceRejetee)
- Étape 8 : recherche fulltext PostgreSQL avec filtres type/lieu/années et CTE récursive pour les subdivisions de lieux
- Étape 9 : export GEDCOM 5.5.1 (GedcomExportService + DateConversionService)
- Types de lieux : CRUD admin (LieuTypeController) avec champ ordre
- Composant lieu-picker : modale Alpine.js avec recherche AJAX + debounce
- Filtres sources : statut, type, lieu (CTE récursive), période annee_debut/annee_fin
- Filtres lieux : type, texte, lieu parent avec descendants (CTE récursive)
- Migration : lieu_id + annee_debut + annee_fin sur sources
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com >
2026-06-04 17:17:53 +02:00