Files
Classeo/backend/migrations/Version20260224214219.php
Mathias STRASSER 2420e35492 feat: Permettre l'import d'élèves via fichier CSV ou XLSX
L'import manuel élève par élève est fastidieux pour les établissements
qui gèrent des centaines d'élèves. Un wizard d'import en 4 étapes
(upload → mapping → preview → confirmation) permet de traiter un
fichier complet en une seule opération, avec détection automatique
du format (Pronote, École Directe) et validation avant import.

L'import est traité de manière asynchrone via Messenger pour ne pas
bloquer l'interface, avec suivi de progression en temps réel et
réutilisation des mappings entre imports successifs.
2026-02-25 16:51:13 +01:00

35 lines
870 B
PHP

<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20260224214219 extends AbstractMigration
{
public function getDescription(): string
{
return 'Ajouter la table saved_column_mappings pour réutiliser les mappings d\'import';
}
public function up(Schema $schema): void
{
$this->addSql(<<<'SQL'
CREATE TABLE saved_column_mappings (
tenant_id UUID NOT NULL,
format VARCHAR(50) NOT NULL,
mapping_data JSONB NOT NULL,
saved_at TIMESTAMPTZ NOT NULL,
PRIMARY KEY (tenant_id, format)
)
SQL);
}
public function down(Schema $schema): void
{
$this->addSql('DROP TABLE saved_column_mappings');
}
}